移动前端适配一直困扰不少人,我本身也是从最初的媒体查询,到后来的百分比,再到padding-top这种奇巧淫技,再到css3新单位vw这种过渡转变 但这些都或多或少会有些问题,直到使用了动态rem 才真正再也不在适配这个问题上发愁 只由于叫动态rem 是由于他是真正意义上随着屏幕的大小来变化的。css
rem官方解释是 font size of the root element 字面意思就是 根元素的font-size值 也就是rem是相对于元素的html
以下代码:前端
<html> <meta charset="utf-8"/> <head> <style> html{ font-size:10px;} .p1{font-size:1rem;} .p2{ font-size:2rem;} </style> </head> <body> <p class="p1">这是一个1rem字体</p> <p class="p2">这是一个2rem的字体</p> </doby> </html>
从最终效果能够看出文档中元素的字体大小是基于html根元素的 p1的font-size为10px p2的font-size是20pxcss3
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
在移动开发时咱们都会有上面这段代码sass
dpr(device pixel ratio)app
设备像素比dpr 要了解这一律念还得清楚另外两个概念iphone
设备物理像素函数
通俗的讲设备屏幕有多少个能够闪烁的点 是一个具体的概念 好比iphone6横向就有750个能够改变颜色的点 相似与电视机 若是家里有10年前买的大头电视,你趴在屏幕前仔细看能看到一个个RGB的点 这就是设备的物理像素字体
设备独立像素.net
设备独立像素是一个虚拟的概念,如程序中的css 好比咱们将一个div宽度设置为10像素 那么在pc上系统会将这个div显示在屏幕的10个点上
经过上面的rem,viewport,以及dpr咱们就能够完成咱们的终极适配了,告别死板写法 再也不这样写死 咱们知道了设备的dpr就能够明确的知道缩放多少,并且这样还解决了很难解决的1px横线的问题
咱们须要这样一段js代码
(function (doc, win) { console.log("dpr:"+win.devicePixelRatio); var docEle = doc.documentElement, isIos = navigator.userAgent.match(/iphone|ipod|ipad/gi), dpr=Math.min(win.devicePixelRatio, 3); scale = 1 / dpr, resizeEvent = 'orientationchange' in window ? 'orientationchange' : 'resize'; docEle.dataset.dpr = dpr; var metaEle = doc.createElement('meta'); metaEle.name = 'viewport'; metaEle.content = 'initial-scale=' + scale + ',maximum-scale=' + scale; docEle.firstElementChild.appendChild(metaEle); var recalCulate = function { var width = docEle.clientWidth; if (width / dpr > 640) { width = 640 * dpr; } docEle.style.fontSize = 20 * (width / 750) + 'px'; }; recalCulate if (!doc.addEventListener) return; win.addEventListener(resizeEvent, recalCulate, false); })(document, window);
最终效果
当咱们拿到psd的时候可能要把psd的图尺寸转换为rem,以前一个同事有一个很好的方法能够彻底按照psd的的尺寸来书写,但要用到sass,使用sass能够大大提升开发效率,下面是sass的一个mixin方法将rem和px作了转换 以下hotcss.scss
@function px2rem( $px ){ @return $px*750/$designWidth/20 + rem; //这句是否是感受很熟悉 这句其实跟上面的那段js是对应的 } $designWidth : 750; //如设计图是750
在咱们的style.scss中
@import 'px2rem.scss'; $designWidth : 750; //如设计图是750 .banner{width:px2rem(300)}//如设计稿上的banner是300px 就免去计算环节
转载请注明:小月博客 » 动态rem解决移动前端适配