1. 安装lib-flexible:
npm i -S amfe-flexible(注意:lib-flexible尝试后,换算结果不正确,切记不要用)
2.安装px2rem:
npm install px2rem-loader
3.在项目入口文件main.js中引入lib-flexible
import 'amfe-flexible';
4. 在项目public目录的index.html头部加入手机端适配的meta的代码 <meta name="viewport" content="width=device-width, initial-scale=1.0">
5.这里是重要的一步~~css
在build文件中找到util.js,将px2rem-loader添加到cssLoaders中,如:html
const cssLoader = { loader: 'css-loader', options: { minimize: process.env.NODE_ENV === 'production', sourceMap: options.sourceMap } } const px2remLoader = { loader: 'px2rem-loader', options: { remUnit: 75
//注意: remUnit在这里要根据lib-flexible的规则来配制,若是您的设计稿是750px的,用75就刚恰好。
} }
同时,在generateLoaders方法中添加px2remLoadernpm
function generateLoaders (loader, loaderOptions) { const loaders = options.usePostCSS ? [cssLoader, postcssLoader, px2remLoader] : [cssLoader, px2remLoader] if (loader) { loaders.push({ loader: loader + '-loader', options: Object.assign({}, loaderOptions, { sourceMap: options.sourceMap }) }) }
当配置完以后,只须要重启下服务,就自动转化为rem了post
npm run dev
7.舒适提示
当你遇到1px的边框时,一般容易发现页面缺失部分边框,这时你能够使用/*no*/语法来屏蔽该属性转换,例如:
border: 1px solid red; /*no*/
因为字体的特殊性,咱们在编译font-size属性时,一般不使用rem单位,这时候你能够这样使用:
font-size: 24px; /*px*/
---------------------
做者:娄笙悦
来源:CSDN
原文:https://blog.csdn.net/weixin_41424247/article/details/80867351
版权声明:本文为博主原创文章,转载请附上博文连接!