标签:data- 不同 scale 框架 name script var 方便 cti
meida queries
的方式可以说是我早期采用的布局方式,它主要是通过查询设备的宽度来执行不同的 css
代码,最终达到界面的配置。核心语法是:
@media screen and (max-width: 600px) { /*当屏幕尺寸小于600px时,应用下面的CSS样式*/
/*你的css代码*/
}
media query
可以做到设备像素比的判断,方法简单,成本低,特别是对移动和PC维护同一套代码的时候。目前像Bootstrap
等框架使用这种方式布局它的viewport
是固定的:<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
根据rem
将页面放大dpr
倍, 然后viewport
设置为1/dpr
.
viewport
设置为1/3, 这样页面整体缩回原始大小. 从而实现高清。这样整个网页在设备内显示时的页面宽度就会等于设备逻辑像素大小,也就是device-width
。这个device-width
的计算公式为:
设备的物理分辨率/(devicePixelRatio * scale)
,在scale
为1的情况下,device-width = 设备的物理分辨率/devicePixelRatio
。
通过以下代码来控制rem
基准值(设计稿以720px
宽度量取实际尺寸)
!function (d) {
var c = d.document;
var a = c.documentElement;
var b = d.devicePixelRatio;
var f;
function e() {
var h = a.getBoundingClientRect().width, g;
if (b === 1) {
h = 720
}
if(h>720) h = 720;//设置基准值的极限值
g = h / 7.2;
a.style.fontSize = g + "px"
}
if (b > 2) {
b = 3
} else {
if (b > 1) {
b = 2
} else {
b = 1
}
}
a.setAttribute("data-dpr", b);
d.addEventListener("resize", function () {
clearTimeout(f);
f = setTimeout(e, 200)
}, false);
e()
}(window);
标签:data- 不同 scale 框架 name script var 方便 cti
原文地址:http://www.cnblogs.com/xzma/p/7131731.html