骚年,放飞自我吧!放心使用 vw 来做适配~
移动端h5 vw 适配,基于webpack4 打包多页面html demo、支持es6,开箱即用。
适合小白哈,大佬看到点完小星星✨再绕路~小白也别忘记了点个星星!谢谢~
1、在这里很多人有疑问,为什么要用vw 单位来做适配?vw 和 我们常用rem适配方案有什么优缺点?
我相信大家对vw 和 rem 单位不会陌生。
vw、vh、vmin、vmax 这四个单位都是相对于视口的宽度。视口被均分为100单位的vw :
vw、vh vw是相对视口(viewport)的宽度而定的,长度等于视口宽度的1/100。 假如浏览器的宽度为200px,那么1vw就等于2px(200px/100)。
vh是相对视口(viewport)的高度而定的,长度等于视口高度的1/100。 假如浏览器的高度为500px,那么1vh就等于5px(500px/100)。
vmin和vmax是相对于视口的高度和宽度两者之间的最小值或最大值。
如果浏览器的高为300px、宽为500px,那么1vmin就是3px,1vmax就是5px。 如果浏览器的高为800px,宽为1080px,那么1vmin也是8px,1vmax也是10.8px。
弹性布局通常指的是rem或em布局,rem是相对于html元素的font-size大小而言的,而em是相对于其父元素(非font-size的是相对于自身的font-size)。 10px == 62.5%
html {font-size: 62.5%;/*10 ÷ 16 × 100% = 62.5%*/}
body {font-size: 1.4rem;/*1.4 × 10px = 14px */}
h1 { font-size: 2.4rem;/*2.4 × 10px = 24px*/}
不管vw 还是rem 都是非常不错的一个长度单位,rem 适配的代表Flexible.js 方案,被绝大部分公司引用,2013年那时,移动端兴起,需要适配多端。
当时rem 和 vw 两个选择? vw 在当时的条件下不够成熟用来做适配的方案,因为那时候的厂商对vw 的适配支持率低、兼容性差。但是现在对移动端来说,大部分都已经支持vw的适配了,具体兼容的数据,可以看 =>2
rem 的弹性布局,在当时无疑成了不二的选择,兼容性好,不过有些小问题,都能hack,flexible可以说是一个非常优秀的方案,也承载了一段时期的适配使命。大家有时间可以翻翻flexible 的源码,通过js 动态改变根节点,来使rem 单位达到适配多端的效果。
rem 是根据各种规则计算一个宽度,然后把根元素的字体尺寸设置成这个宽度,然后使用rem设置各种子元素的宽度。其实最终rem 也是在模拟 vw ,那在现在大部分厂商都支持vw ,并且也有降级处理方案可以hack,我们何不直接用vw 呢,相信未来会有越来越多的厂商完善支持vw。
包括flexible 团队也建议大家可以放弃使用这个过渡的方案,可以采用vw 来解决适配问题。
2、现在对vw 的兼容性支持情况?
在移动端 iOS 8 以上、 Android 4.4 以上、包括微信浏览器 新版x5 都支持vw。
可以在 Can I use 或者 css3test 查看兼容情况
想要适配低版本浏览器、低端机型也不是什么问题、也给出了解决方案。请看 => 3
在几年前vw 之所以没有流行起来的原因,还是因为在当时兼容性不够,讲白了,就是坑多、大家都不愿意做第一个躺坑的人。
几年时间过去,各大厂商对vw 对兼容升级、低端机型占比逐步减少,vw 的适配方案也慢慢的浮出了水面,大家重新对它有了新的认识。包括我们业界知名的大漠,他们在手淘已经对vw 适配方案有了一年多的实践时间。
3、不支持vw 的浏览器的解决方案?
低版本浏览器、低端机型不支持的情况下,我们可以hack ,在部分浏览器上不显示图片,可以加上全局解决 img {content: normal !important} https://github.com/rodneyrehm/viewport-units-buggyfill 项目中引用
window.onload=function() {window.viewportUnitsBuggyfill.init({hacks:window.viewportUnitsBuggyfillHacks }); }
github 欢迎小星星 请点击: vw 适配 github 地址
如果你已经装了git 的话,可以走以下步骤。
git clone https://github.com/caoxiaoke/html-vw-layout.git
cd html-vw-layout
执行步骤:npm install 或者 sudo npm install
开发环境 npm run start || 开发环境 http://localhost:8080 查看效果
生产打包 npm run build
如果你不使用react 也不使用vue ,在项目中只使用html页面 vw实现移动端适配,请点这 《如何在html项目中使用vw实现移动端适配》
在react项目中使用vw实现移动端适配 请参考 《如何在react项目中使用vw实现移动端适配》
###Demo
Galaxy Note 3
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/Galaxy%20Note%203.png
Galaxy S5
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/Galaxy%20S5.png
Nexus 7 https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/Nexus%207.png
iPad Pro
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPad%20Pro.png
iPad
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPad.png
iPhone 5_SE
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPhone%205_SE.png
iPhone 6_7_8 Plus
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPhone%206_7_8%20Plus.png
iPhone 6_7_8
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPhone%206_7_8.png
iPhone X
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/iPhone%20X.png
华为P10 PLUS 1440_2560
华为P20
https://github.com/caoxiaoke/html-vw-layout/blob/master/src/images/%E5%8D%8E%E4%B8%BAP20.png
iPhone 6_7_8