Vue:将px转化为rem,在移动端进行自适应

1.下载lib-flexible

我使用vue-cli搭建的环境,通过npm来安装

npm i lib-flexible --save

2.引入lib-flexible

在main.js中引入lib-flesible

import 'lib-flexible/flexible'

3.再安装px2rem-loader

npm install px2rem-loader

4.配置px2rem-loader

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

  const cssLoader = {
    loader: 'css-loader',
    options: {
      sourceMap: options.sourceMap
    }
  }

//将px2rem-loader添加到cssLoader中。我这里设计稿750,因此设定75
  const px2remLoader = {
    loader: 'px2rem-loader',
    options: {
      remUnit: 75
    }
  }

  const postcssLoader = {
    loader: 'postcss-loader',
    options: {
      sourceMap: options.sourceMap
    }
  }

同时,在generateLoaders方法中添加px2remLoader

 function generateLoaders (loader, loaderOptions) {

// const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader] 改为
    const loaders =  [cssLoader,px2remLoader]

    if (loader) {
      loaders.push({
        loader: loader + '-loader',
        options: Object.assign({}, loaderOptions, {
          sourceMap: options.sourceMap
        })
      })
    }

5.重启,就可以把px转化为rem  

一般移动端设计稿是放大2倍设计的,所有可以直接用设计稿标注的尺寸大小(即px)

你可能感兴趣的:(vue)