npm install lib-flexible --save
npm install postcss-px2rem --save
简要介绍这两个包的用途:css
例如在Galaxy S III:html
例如在iphone6/7/8:vue
postcss-px2rem会将px转换为rem,rem单位用于适配不一样宽度的屏幕,根据<html>标签的font-size值来计算出结果,1rem=html标签的font-size值。vue-cli
在项目入口文件main.js 中引入lib-flexiblenpm
import 'lib-flexible'
注意事项(important): 因为flexible会动态给页面header中添加<meta name='viewport' >标签,因此务必请把目录 public/index.html 中的这个标签删除!!!浏览器
vue-cli3 构建的项目相较于vue-cli2 构建的项目精简了许多,将一些默认配置进行了更好更严密,让开发变得更高效的封装。具体请看vue-cli官网 https://cli.vuejs.org/zh/guide/框架
px2rem的配置放在vue-cli3 项目中vue.config.js中(找不到?可能你是一个新构建的项目,须要手动在项目根目录建立vue.config.js)iphone
具体配置内容以下:ide
1 module.exports = { 2 css: { 3 loaderOptions: { 4 css: {}, 5 postcss: { 6 plugins: [ 7 require('postcss-px2rem')({ 8 remUnit: 37.5 9 }) 10 ] 11 } 12 } 13 }, 14 }
OK,重启项目,两个用于移动端适配的包就这样能够愉快的开始使用了!!!post
下面来看咱们的代码,代码中咱们直接用px来写宽高:
1 .testclass { 2 width: 300px; 3 height: 200px; 4 background: #e3e3e3; 5 }
在浏览器中会是什么样的呢?
没错,已经从px转换成了rem。 what?若是你的没有从px变成rem, 那么你可能须要重启一下项目呦~
舒适提示: remUnit这个配置项的数值是多少呢??? 一般咱们是根据设计图来定这个值,缘由很简单,便于开发。假如设计图给的宽度是750,咱们一般就会把remUnit设置为75,这样咱们写样式时,能够直接按照设计图标注的宽高来1:1还原开发。
那为何你在这里写成了37.5呢???那咱们后面专门来说!
之因此设为37.5,是为了引用像mint-ui这样的第三方UI框架,由于第三方框架没有兼容px2rem ,将remUnit的值设置为设计图宽度(这里为750px)75的一半,便可以1:1还原mint-ui的组件,不然会样式会有变化,例如按钮会变小。
既然设置成了37.5 那么咱们必须在写样式时,也将值改成设计图的一半。