zoukankan      html  css  js  c++  java
  • 【极致丝滑】利用postcss-px2vw-pv彻底摆脱编辑器插件,灵活可控地转换px至vw

    背景

    • 旧的rem适配方案(无论是直接使用rem,还是配合flexiblejs等lib库进行视口缩放)已经疲态尽显,且随着安卓高清屏的不断出现,同时data-dpr仍有进一步增加的可能性,rem显得并不是那么稳固与称心如意。

    • 首先截止至发文日期,viewport的兼容性如下:

      可以看到,viewport的兼容性支持已经变得非常好,因此有机会抛弃一切外接库,直接使用原生的viewport。就像最早使用sublime到现在的vscode,都需要重新配置插件px2rem, 换了编辑器,换了环境,开发就会变得很陌生。再加上不同插件快捷键触发条件也不同,这就给原本就很煎熬的前端开发又增加了复杂度。好在postcss出现了,它允许我们用更加彻底(相比less和scss而言)的编程思维或者说面向对象的思维去对css做预处理。

    • 回到px转vw的问题上,首先需要在你的构建工具上安装配置postcss,然后以此插件: postcss-px2vw-pv 解决:

    • 最新官方文档: https://github.com/pomelott/postcss-px2vw-pv

    • 此插件使用全新的置换单位pv,没有过多复杂的配置,用postcss自动对各种复杂css样式做计算与转换,而不必在开发过程中再考虑各种快捷键、编辑器插件以及转换配置等。

    安装

        npm i postcss-px2vm-pv -D
    
        yarn add postcss-px2vw-pv --dev
    

    配置选项

    选项 类型 默认值 描述
    width number 750 设计稿像素宽度
    decimal number 4 换算后小数点后的保留位数
        module.exports = {
            plugins: [
                require('postcss-px2vw-pv')({
                       1080
                })
            ]
        }
    

    快速使用

    • 首先添加postcss至开发环境中,此处不做赘述,不明白的可上postcss官方查看。
    • 例如:
        module.exports = {
            plugins: [
                require('postcss-px2vw-pv')
            ]
        }
    
    • 然后对postcss-px2vw-pv进行配置,或使用默认配置项也可。
    • 例如一个div的宽度是 ’500px‘, 那么你可以使用 ’500pv‘ 进行替换,插件会根据设计稿宽度自动计算并生成新的css样式。

    小例子

    • 在750宽度的设计稿下, 使用500px的宽度, 10px的横向位移
        .box {
             500pv;
            transform: translateX(10pv);
        }
    
    • 生成的最终样式如下:
        .box {
             66.666667vw;
            transform: translateX(1.333333vw);
        }
    
  • 相关阅读:
    看opengl写代码(7) 使用混合数组(glInterLeavedArrays)
    三层交换机静态路由配置实现两网互通
    [leetcode] Insertion Sort List(python)
    Android 4.4环境搭建——配置AVD模拟器
    QlikView格式化某一个单元格
    浅谈触发器
    为什么镜像是左右而不是上下颠倒:4星|《环球科学》2018年08月号
    “第一公里”仍鲜被问津:4.5星|《财经》2018年第19期
    用故事做营销或管理,相关的8本书
    知识付费与内容创业相关的书9本
  • 原文地址:https://www.cnblogs.com/pomelott/p/13648495.html
Copyright © 2011-2022 走看看