Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)

时间:2021-01-28 14:41:57

转载:https://www.cnblogs.com/WQLong/p/7798822.html

1.下载lib-flexible

使用的是vue-cli+webpack,通过npm来安装的

npm i lib-flexible --save

2.引入lib-flexible

在main.js中引入lib-flexible

import 'lib-flexible/flexible'

3.设置meta标签

通过meta标签,设置设备宽度以及缩放比例

<meta name="viewport" content="width=device-width, initial-scale=1.0">

4.安装px2rem-loader

npm install px2rem-loader

5.配置px2rem-loader

这里是重要的一步~~

在build文件中找到util.js,将px2rem-loader添加到cssLoaders中,如:

Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)
 
const cssLoader = {
loader: 'css-loader',
options: {
minimize: process.env.NODE_ENV === 'production',
sourceMap: options.sourceMap
}
}
const px2remLoader = {
loader: 'px2rem-loader',
options: {
remUnit: 75 // 这里设置html根字体,vant-UI的官方根字体大小是37.5
}
}
 
Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)

同时,在generateLoaders方法中添加px2remLoader

Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)
 

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
  })
  })
  }

if (options.extract) {
  return ExtractTextPlugin.extract({
  use: loaders,
  fallback: 'vue-style-loader'
  })
  } else {
  return ['vue-style-loader'].concat(loaders)
  }
}

 
Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)

6.重启,一切ok~

当配置完之后,只需要重启下服务,就自动转化为rem了

npm run dev

Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)

Vue:将px转化为rem,适配移动端vant-UI等框架(px2rem-loader)