最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 快速入门 postcss 插件:自动转换 px 到 rem - 掘金

    正文概述 掘金(zxg_神说要有光)   2021-11-18   889

    postcss 是 css 的 transpiler(转换编译器,简称转译器),它对于 css 就像 babel 对于 js 一样,能够做 css 代码的分析和转换。同时,它也提供了插件机制来做自定义的转换。

    这一节,我们通过一个 px 自动转 rem 的功能来入门一下 postcss 的插件。

    postcss 的原理

    postcss 是 css 到 css 的转译器,它也和 babel 一样,分为 parse、transform、generate 3个阶段。各种转换插件都是工作在 transform 阶段,基于 AST 做分析和转换。

    快速入门 postcss 插件:自动转换 px 到 rem  - 掘金

    css 的 AST 比 js 的简单多了,主要有这么几种:

    atrule:以 @ 开头的规则,比如:

    @media screen and (min-width: 480px) {
        body {
            background-color: lightgreen;
        }
    }
    

    rule:选择器开头的规则,比如:

    ul li {
    	padding: 5px;
    }
    

    decl:具体的样式,比如:

    padding: 5px;
    

    比起 js parser 的那几十种 AST 是不是简单的多?

    这些可以通过 astexplorer.net 来可视化的查看

    快速入门 postcss 插件:自动转换 px 到 rem  - 掘金

    postcss 插件的写法

    postcss 插件是工作在 transform 阶段,处理 ast 节点,插件的形式是这样的:

    const plugin = (options = {}) => {
      return {
        postcssPlugin: '插件名字',
    
        Rule (node) {},
        Declaration (node) {},
        AtRule (node) {}
      }
    }
    

    外层函数接受 options,返回一个插件的对象,声明对什么节点做处理的 listener,然后在对应的 listener 里写处理逻辑就行。

    还可以这样写:

    module.exports = (opts = {}) => {
      return {
        postcssPlugin: '插件名字',
        prepare (result) {
          // 这里可以放一些公共的逻辑
          return {
            Declaration (node) {},
            Rule (node) {},
            AtRule (node) {}
          }
        }
      }
    }
    

    在 prepare 里返回各种 listener,这样比起第一种来,好处是可以存放一些公共的逻辑。

    然后可以这样来运行插件:

    const postcss = require('postcss');
    
    postcss([plugin({
        // options
    })]).process('a { font-size: 20px; }').then(result => {
        console.log(result.css);
    })
    

    下面我们来写一个简易的 px 自动转 rem 的插件来练练手。

    实战案例

    需求描述

    px 是一个固定的长度单位,而设备视口的尺寸是各种各样的,我们想通过一套样式来适配各种设备的显示,就需要相对的单位,常用的是 rem。

    rem 的本质就是等比缩放,相对于 html 元素的 font-size。

    比如 html 的 font-size 设置为 100px,那 1rem 就等于 100px,之后的样式如果是 200px 就写为 2rem。

    这样我们只需要修改 html 的 font-size 就可以适配各种屏幕宽度的显示,具体的单位会做等比缩放。

    我们要根据 html 的 font-size 值来把所有的 px 转换为 rem,一般都是手动来做这件事情的,但比较繁琐,知道了计算方式之后,完全可以用 postcss 插件来自动做。

    接下来我们就实现下这个 postcss 插件

    代码实现

    我们搭一下插件的基本结构,只需要声明对 Declaration 处理的 listener:

    const plugin = (options) => {
        return {
            postcssPlugin: 'postcss-simple-px2rem',
            Declaration (decl) {
               
            }
        }
    }
    

    然后要做的就是把 decl 的样式值中的 px 转换为 rem,简单的正则替换就行:

    const plugin = (options) => {
        const pxReg = /(\d+)px/ig;
        return {
            postcssPlugin: 'postcss-simple-px2rem',
            Declaration (decl) {
                decl.value = decl.value.replace(pxReg, (matchStr, num) => {
                    return num/options.base + 'rem';
                });
            }
        }
    }
    

    通过字符串的 replace 方法来做替换,第一个参数是匹配的字符串,后面的参数是分组,第一个分组就是 px 的值。

    计算 px 对应的 rem 需要 1rem 对应的 px 值,可以支持通过 options 来传入。

    然后我们测试下:

    postcss([plugin({
        base: 100
    })]).process('a { font-size: 20px; }').then(result => {
        console.log(result.css);
    })
    

    可以看到,已经正确的做了转换:

    快速入门 postcss 插件:自动转换 px 到 rem  - 掘金

    当然,我们这个插件只是案例,还不够完善,要做的完善的话需要更复杂的正则。

    总结

    postcss 是 css 的 transpiler,就像 babel 是 js 的 transpiler 一样,而且 postcss 的 AST 只有几种节点,比较简单,也可以通过 astexplorer.net 来可视化的查看。

    postcss 也提供了插件功能,可以做一些自定义的分析和转换。

    我们实现了简单的 px 自动转 rem 的插件:

    rem 是通过等比缩放的方式来达到一套样式适配不同设备宽度的显示的方案,需要做 px 到 rem 的转换,这件事可以用 postcss 插件来自动来做。

    其实 postcss 插件的分析和转换功能还有很多的应用,比如切换主题色,从白到黑,完全就可以用 postcss 自动分析颜色的值,然后做转换。

    postcss 分析和转换 css 的能力还是很强大很有用的,有很多在业务中的应用场景等你去发掘。


    起源地下载网 » 快速入门 postcss 插件:自动转换 px 到 rem - 掘金

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元