移动端适配实践
viewport 视图、视窗
移动端设备中,整块显示屏就相当于视图、视窗
在移动端设备中, 浏览器视图并不是整个屏幕。因此viewport又被分为了3种layout viewport 、visual viewport、ideal viewport
layout viewport
大部分浏览器把viewport的宽度设为了980px 这个浏览器默认设置的视图被称为 layout viewport。我们可以使用document.documentElement.clientWidth 来获取
lvisual viewport
layout viewport的宽度是远大于浏览器宽度的,因此我们需要一个新的viewport来代表浏览器的可视区域宽度,这个视图则被成为 visual viewport 我们可以使用 window.innerWidth 来获取
ideal viewport
现在越来越多的网站都会为移动设备进行单独的设计,所以必须还要有一个能完美适配移动设备的ideal viewport
viewport 单位 vw、vh
vw、vh将viewport分成了一百份。vw即 viewport width vh即viewport height
1vw等于视图单位的1%的宽度
1vh等于视图单位的1%的高度
如果设计稿的视图为375px 那么1vw 等于 3.75px
要使用viewport适配 我们必须安装postcss-px-to-viewport
这个包。这包和postcss-pxtorem
类似。
不仅名字相似,功能也有相似的地方
postcss-pxtorem
是将 px单位转换为rem单位。
postcss-px-to-viewport
则是将px单位转换为vw、vh
1 |
|
安装完成后 我们需要进行postcss插件相关的配置,在根目录新建一个名为postcss.config.js的文件,如果项目中已包含该文件则无需新建。在文件中写入如下代码:
1 |
|
注意:
postcss-px-to-viewport
同样存在第三方组件库兼容性的问题。比如在设计稿为750px时使用vant组件库会将vant组件的样式缩小。
vant组件库的设计稿是按照375px来开发的。因此在viewportWidth
为750px
时会出现转换问题
解决第三方组件库兼容性问题
基于postcss-px-to-viewport,只是增加了可以配置不同的设计稿尺寸,比如当使用vant时,375的设计尺寸可能与你的要求不符合
原理:在src/index.js中加入了以下代码,把当前文件路径暴露出去,接收一个新的viewportWidth并赋值给opts
1 |
|
下面是配置:
1 |
|
读取的node_modules中的文件是vant,那么就将设计稿变为375px。如果读取的文件不是vant的文件,那么就将设计稿变为750px。这样就可以避免vant组件在750px下出现样式缩小的问题了。
总结
解决移动端适配的问题,形成模板,在团队内部推广。
px -> rem 的形式,使用上效率不高(自己去算,获取其他方式),还不太工程化,麻烦且难以维护。
因此我引入了这种方式,形成了一套模板,并集成到脚手架之中, 提升团队研发效率。