postcss.config.js 动态配置基准值

在Vue项目中引入PostCSS可以实现不同分辨率的自适应,通常在H5项目中使用

  1. 安装插件
bash 复制代码
npm install --save-dev postcss postcss-loader autoprefixer
  1. 新建postcss.config.js文件,添加下列配置项
javascript 复制代码
module.exports = {
  plugins: {
    'postcss-px-to-viewport': {
      unitToConvert: 'px', // 要转换的单位
      viewportWidth: 750, // 设计稿宽度
      unitPrecision: 5, // 单位转换后保留的精度
      propList: ['*'], // 指定转换那些属性,*表示全部
      viewportUnit: 'vw', // 希望使用的视口单位
      fontViewportUnit: 'vw', // 字体使用的视口单位
      selectorBlackList: [], // 要忽略的选择器
      minPixelValue: 1, // 最小的转换数值
      mediaQuery: false, // 是否在媒体查询中也转换px
      replace: true, // 是否直接更换属性值
      exclude: /(\/|\\)(node_modules)(\/|\\)/, // 忽略某些文件夹下的文件或者某些特定文件
    }
  }
}
  1. 如果一个H5项目,即有移动端的页面,又有PC端的页面,且为不同迟勋的设计稿,移动端的H5需要根据屏幕进行自适应,而PC端不需要进行自适应,或者因为设计稿不同,设置的基准值和移动端不是同一个。这种情况下可以通过文件路径去判断我们要设置什么样的基准值了
javascript 复制代码
module.exports = ((value) => {
  // 不让页面随屏幕的变化而变大变小的文件名称
  let originalSizePage = ['homePc']
  // 文件路径,包括文件名称
  let path = value.webpack.resourcePath
  // 该文件是否要设置基准值(是否要根据屏幕分辨率去缩放)
  let isOriginalSize = false
  if(path){
    originalSizePage.forEach(name => {
      if(path.includes(name)){
        isOriginalSize = true
      }
    })
  }
  // console.log("**webpack: --" , path, isOriginalSize)

  if(isOriginalSize){
    // 不需要缩放
    return {}
  }else{
    // 需要缩放
    return {
      plugins: {
        'postcss-px-to-viewport': {
          unitToConvert: 'px', // 要转换的单位
          viewportWidth: 750, // 设计稿宽度, 可以根据文件名称不定义不同的宽度 flag ? 1920 : 750
          unitPrecision: 5, // 单位转换后保留的精度
          propList: ['*'], // 指定转换那些属性,*表示全部
          viewportUnit: 'vw', // 希望使用的视口单位
          fontViewportUnit: 'vw', // 字体使用的视口单位
          selectorBlackList: [], // 要忽略的选择器
          minPixelValue: 1, // 最小的转换数值
          mediaQuery: false, // 是否在媒体查询中也转换px
          replace: true, // 是否直接更换属性值
          exclude: /(\/|\\)(node_modules)(\/|\\)/, // 忽略某些文件夹下的文件或者某些特定文件
        }
      }
    }
  }
})
相关推荐
肥肥呀呀呀12 分钟前
在Flutter上如何实现按钮的拖拽效果
前端·javascript·flutter
付朝鲜1 小时前
用自写的jQuery库+Ajax实现了省市联动
java·前端·javascript·ajax·jquery
coderYYY1 小时前
多个el-form-item两列布局排齐且el-select/el-input组件宽度撑满
前端·javascript·vue.js·elementui·前端框架
Watermelo6172 小时前
前端如何应对精确数字运算?用BigNumber.js解决JavaScript原生Number类型在处理大数或高精度计算时的局限性
开发语言·前端·javascript·vue.js·前端框架·vue·es6
HebyH_2 小时前
2025前端面试遇到的问题(vue+uniapp+js+css)
前端·javascript·vue.js·面试·uni-app
EndingCoder4 小时前
2025年JavaScript性能优化全攻略
开发语言·javascript·性能优化
a濯10 小时前
element plus el-table多选框跨页多选保留
javascript·vue.js
九月TTS12 小时前
开源分享:TTS-Web-Vue系列:Vue3实现固定顶部与吸顶模式组件
前端·vue.js·开源
H3091912 小时前
vue3+dhtmlx-gantt实现甘特图展示
android·javascript·甘特图
CodeCraft Studio12 小时前
数据透视表控件DHTMLX Pivot v2.1发布,新增HTML 模板、增强样式等多个功能
前端·javascript·ui·甘特图