vue-cli5中使用postcss-px-to-viewport

项目package.json

 

在项目根目录下的vue.config.js中进行配置

const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  transpileDependencies: true,
  css: {
    loaderOptions: {
      postcss: {
        postcssOptions: {
          plugins: [
            [
              'postcss-px-to-viewport',
              {
                unitToConvert: 'px',    // 需要转换的单位,默认为"px"
                viewportWidth: 375,     // 设计稿的视窗宽度
                unitPrecision: 5,       // 单位转换后保留的精度
                propList: ['*', '!font-size'],        // 能转化为 vw 的属性列表
                viewportUnit: 'vw',     // 希望使用的视窗单位
                fontViewportUnit: 'vw', // 字体使用的视窗单位
                selectorBlackList: [],  // 需要忽略的 CSS 选择器,不会转为视窗单位,使用原有的 px 等单位
                minPixelValue: 1,       // 设置最小的转换数值,如果为 1 的话,只有大于 1 的值会被转换
                mediaQuery: false,      // 媒体查询里的单位是否需要转换单位
                replace: true,          // 是否直接更换属性值,而不添加备用属性
                exclude: undefined,     // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件
                include: /\/src\//,     // 如果设置了include,那将只有匹配到的文件才会被转换
                landscape: false,       // 是否添加根据 landscapeWidth 生成的媒体查询条件
                landscapeUnit: 'vw',    // 横屏时使用的单位
                landscapeWidth: 1125,   // 横屏时使用的视窗宽度
              },
            ],
          ],
        },
      }
    }
  }
})

直接在vue组件中使用

打开浏览器查看效果,可以看到px成功转换为vw单位

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值