做为一个小前端,常常要和H5打交道,这就面临着不一样终端的适配问题。
Flexible方案经过Hack手段来根据设备的dpr
值相应改变<meta>
标签中viewport
的值,给我更贴切的体会就是经过js脚本根据设备的dpr和设计图的宽度来计算出html
的font-size
值,而后就运用rem
单位开发能够等比例缩放的H5页面。
可是!Flexible已经完成了他自身的历史使命,咱们能够放下Flexible,拥抱新的变化。css
在移动端布局,咱们须要面对两个最为重要的问题:html
1px
、2x
图等一系列的问题。那么这个布局方案也是针对性的解决这些问题,只不过解决这些问题再也不是使用Hack手段来处理,而是直接使用原生的CSS技术来处理的。之前的Flexible方案是经过JavaScript来模拟vw
的特性,那么到今天为止,vw
已经获得了众多浏览器的支持,也就是说,能够直接考虑将vw
单位运用于咱们的适配布局中。前端
vw
是基于Viewport视窗的长度单位,这里的视窗(Viewport)指的就是浏览器可视化的区域,而这个可视区域是window.innerWidth/window.innerHeight
的大小。用下图简单的来示意一下:
css3
在CSS Values and Units Module Level 3中和Viewport相关的单位有四个,分别为vw
、vh
、vmin
和vmax
。git
vw
:是Viewport's width的简写,1vw
等于window.innerWidth
的1%
vh
:和vw
相似,是Viewport's height的简写,1vh
等于window.innerHeihgt
的1%
vmin
:vmin
的值是当前vw
和vh
中较小的值vmax
:vmax
的值是当前vw
和vh
中较大的值若是设计稿用750px
宽度的,100vw = 750px
,即1vw = 7.5px
。那么咱们能够根据设计图上的px
值直接转换成对应的vw
值。若是不想本身计算,咱们可使用PostCSS的插件postcss-px-to-viewport,让咱们能够直接在代码中写px
。github
具体的PostCSS咱们放到另一篇文章吧,毕竟我还不会~浏览器