1. 程式人生 > >Vue:將px轉化為rem,適配移動端vant-UI等框架(px2rem-loader)

Vue:將px轉化為rem,適配移動端vant-UI等框架(px2rem-loader)

轉載: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中,如:

複製程式碼  
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
} }
  複製程式碼

同時,在generateLoaders方法中新增px2remLoader

複製程式碼  

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

  複製程式碼

6.重啟,一切ok~

當配置完之後,只需要重啟下服務,就自動轉化為rem了

npm run dev