美文网首页
px 自动转换为 vw

px 自动转换为 vw

作者: PharkiLL | 来源:发表于2022-01-06 11:07 被阅读0次

    设计师一般给宽度大小为 375px 或 750px 的视觉稿,我们采用 vw 方案的话,需要将对应的元素大小单位 px 转换为 vw 单位,这是一项影响开发效率(需要手动计算将 px 转换为 vw)且不利于后续代码维护(css 代码中一堆 vw 单位,不如 px 看的直观)的事情;好在社区提供了 postcss-px-to-viewport 插件,来将 px 自动转换为 vw,相关配置步骤如下:

    安装插件

    npm install postcss-px-to-viewport --save-dev
    

    webpack配置

    postcss.config.js
    webpack配置
    module.exports = {
      plugins: {
        // ...
        'postcss-px-to-viewport': {
          // options
          unitToConvert: 'px',    // 需要转换的单位,默认为"px"
          viewportWidth: 750,     // 设计稿的视窗宽度
          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,   // 横屏时使用的视窗宽度
        },
      },
    };
     
    
    相关配置属性,通过注释一目了然其作用,其中需要强调的点为 propList 属性,我们配置了 font-size 不进行转换 vw,也就是说在不同手机屏幕尺寸下的字体大小是一样的。

    其中 font-size 是否需要根据屏幕大小做适配,或者怎么做,一直是个争论不休的话题;考虑到我们移动端没有平板的需求,且咨询过团队业务设计师的意见,所以对模版进行以上默认配置;当然如果你的视觉要求你的项目要做字体大小适配,修改 propList 属性的配置即可。

    相关文章

      网友评论

          本文标题:px 自动转换为 vw

          本文链接:https://www.haomeiwen.com/subject/xuwlcrtx.html