为什么要做适配
-
为了适应各种移动端设备,完美呈现应有的布局效果 -
各个移动端设备,分辨率大小不一致,网页想铺满整个屏幕,并在各种分辨下等比缩放
适配方案
-
固定高度,宽度百分比适配-布局非常均匀,适合百分比布局 -
固定宽度,改变缩放比例适配-什么情况都可以 -
Rem 适配 -
像素比适配
单位
-
em
根据元素自身的字体大小计算,元素自身16px 1em=16px
-
Rem R -> root
根节点( html ) 根据 html 的字体大小计算其他元素尺寸
百分比适配
固定高度,宽度百分比适配
-
根据设置的大小去设置高度,单位可以用 px 百分比 auto -
常用 Flex 布局 -
百分比宽度
以 640 设计稿为例,在外层容器上设置最大以及最小的宽
#wrapper {
max-width: 640px; /*设置设计稿的宽度*/
min-width: 300px;
margin: 0 auto;
}
后面的区块布局都用百分比,具体元素大小用
px
计算
640 是 320 的 2 倍,老的低端安卓机横向分辨率大多是 320,现在大多模拟分辨率为 360
rem 适配(常用)
-
根据屏幕的分辨率动态设置 html
的文字大小,达到等比缩放的功能 -
保证 html
最终算出来的字体大小,不能小于12px
-
在不同的移动端显示不同的元素比例效果 -
如果 html
的font-size:20px
的时候,那么此时的1rem = 20px
-
把设计图的宽度分成多少分之一,根据实际情况 -
rem
做盒子的宽度,viewport
缩放
head
加入常见的meta
属性
<meta >
<meta >
<meta >
<!--这个是关键-->
<meta width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0,minimum-scale=1.0">
把这段代码加入
head
中的script
预先加载
// rem适配用这段代码动态计算html的font-size大小
(function(win) {
var docEl = win.document.documentElement;
var timer = '';
function changeRem() {
var width = docEl.getBoundingClientRect().width;
if (width > 750) { // 750是设计稿大小
width = 750;
}
var fontS = width / 10; // 把设备宽度十等分 1rem=10px
docEl.style.fontSize = fontS + "px";
}
win.addEventListener("resize", function() {
clearTimeout(timer);
timer = setTimeout(changeRem, 30);
}, false);
win.addEventListener("pageshow", function(e) {
if (e.persisted) { //清除缓存
clearTimeout(timer);
timer = setTimeout(changeRem, 30);
}
}, false);
changeRem();
})(window)
上面代码是把屏幕分成 10 等份,如果分成 100 份,就和 vw 单位一样了。如果分成 750 份就是微信小程序的概念,以 iphone6 为设计稿(这种最方便清晰)。
像素比适配
-
window.devicePixelRatio
-
物理像素是手机屏幕分辨率 -
独立像素 指 css
像素 屏幕宽度 -
像素比 = 物理像素 / css
宽度 -
获取设备的像素比 window.devicePixelRatio
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/250686.html