正文
最近抽空看了看移动端适配的一些文章,也结合自己的经验做一下总结以及对比。
那么,开始正题,首先说说到目前位置出现的一些关于移动端适配的技术方案:
-
通过媒体查询的方式即
CSS3
的
meida queries
-
以天猫首页为代表的
flex
弹性布局
-
以淘宝首页为代表的
rem
+
viewport
缩放
-
rem
方式
Meida Queries
meida queries
的方式可以说是我早期采用的布局方式,它主要是通过查询设备的宽度来执行不同的
css
代码,最终达到界面的配置。核心语法是:
@media screen and (max-width: 600px) { /*当屏幕尺寸小于600px时,应用下面的CSS样式*/
/*你的css代码*/
}
优点
-
media query
可以做到设备像素比的判断,方法简单,成本低,特别是对移动和PC维护同一套代码的时候。目前像
Bootstrap
等框架使用这种方式布局
-
图片便于修改,只需修改css文件
-
调整屏幕宽度的时候不用刷新页面即可响应式展示
缺点
-
代码量比较大,维护不方便
-
为了兼顾大屏幕或高清设备,会造成其他设备资源浪费,特别是加载图片资源
-
为了兼顾移动端和PC端各自响应式的展示效果,难免会损失各自特有的交互方式
Flex
弹性布局
以天猫的实现方式进行说明:
它的
viewport
是固定的:
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
高度定死,宽度自适应,元素都采用
px
做单位。
随着屏幕宽度变化,页面也会跟着变化,效果就和PC页面的流体布局差不多,在哪个宽度需要调整的时候使用响应式布局调调就行(比如网易新闻),这样就实现了『适配』。
DEMO>>
rem
+
viewport
缩放
这也是淘宝使用的方案,根据屏幕宽度设定
rem
值,需要适配的元素都使用
rem
为单位,不需要适配的元素还是使用
px
为单位。
实现原理
根据
rem
将页面放大
dpr
倍, 然后
viewport
设置为
1/dpr
.
-
如iphone6 plus的dpr为3, 则页面整体放大3倍, 1px(css单位)在plus下默认为3px(物理像素)
-
然后
viewport
设置为1/3, 这样页面整体缩回原始大小. 从而实现高清。
这样整个网页在设备内显示时的页面宽度就会等于设备逻辑像素大小,也就是
device-width
。这个
device-width
的计算公式为:
设备的物理分辨率/(devicePixelRatio * scale)
,在
scale
为1的情况下,
device-width = 设备的物理分辨率/devicePixelRatio
。
具体请查看
github.com/amfe/lib-fl…
或
www.npmjs.com/package/ani…
.
rem
实现
说说我司【魅族】移动端的实现方式,
viewport
也是固定的:
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no">
。
通过以下代码来控制
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);
css
通过
sass
预编译,设置量取的
px
值转化
rem
的变量
$px: (1/100)+rem;
;
1像素边框高清
淘宝实现方式
上面说到的淘宝的实现方式即
rem
+
viewport
缩放来实现。
CSS
代码:
div{
width: 1px;
height: 100%;
display: block;
border-left: 1px solid #e5e5e5;
-webkit-transform: scaleX(.5);
transform: scaleX(.5);
}
缺点: