背景
目录
1 viewport 缩放方案
2 rem 布局适配方案
2.1 动态设置 html 标签 font-size 大小
2.2 元素大小取值方法
2.3 rem 布局方案的开发方式
2.4 字体使用 px 为单位
3 相关参考
拿到设计稿后,如何进行布局还原?
如果只需要做非精确的响应式设计,那么使用媒体查询来实现就 OK 了。如果需要精确还原设计稿,则一般通过缩放来实现。常见方案有基于 viewport 和基于 rem 的缩放方案。
1 viewport 缩放方案
在移动端,可以通过 viewport 缩放页面大小比率达到目的。
简单来说,即所有宽高像素与视觉稿输出相同,然后通过页面宽度与视觉稿的宽度比率,动态设置 viewport。缩放方案核心代码参考:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| (function () { var docEl = document.documentElement; var isMobile = window.isMobile /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Mobi/i.test(navigator.userAgent);
function setScale() { var pageScale = 1;
if (window.top !== window) { return pageScale; }
var width = docEl.clientWidth || 360; var height = docEl.clientHeight || 640; if (width / height >= 360 / 640) { pageScale = height / 640; } else { pageScale = width / 360; }
var content = 'width=' + 360 + ', initial-scale=' + pageScale + ', maximum-scale=' + pageScale + ', user-scalable=no'; document.getElementById('viewport').setAttribute('content', content);
window.pageScale = pageScale; }
if (isMobile) { setScale(); } else { docEl.className += ' pc'; } })()
|
但是如果希望 PC 上也能显示,由于没有 viewport 的缩放概念,只能以固定值来设定,这个效果就不太好。
关于作者
** 珠峰
WEB开发与管理相结合,注重技术与应用结合。现居上海。