关于一个小菜鸡是如何通过自定义 postcss 插件解决 color-mix 兼容问题的

关于一个小菜鸡是如何通过自定义 postcss 插件解决 color-mix 兼容问题的

最近客户反映他们电脑上的颜色展示不正常,经过排查之后发现是引用的第三方组件中,css包含 color-mix 函数。

can i use 上面搜索了一下,刚好客户机器 chrome 是 102 版本的。不支持 color-mix

1. 使用第三方插件 @csstools/postcss-color-mix-function

于是我首先搜索了下 postcss 相关兼容插件,找到了这个 @csstools/postcss-color-mix-function 插件。

www.npmjs.com/package/pos...

但是应用上去并不能生效。估计是因为需要转换的 css 像下面这样

scss 复制代码
color-mix(in srgb, var(--p-primary-color) calc(100% * 1), transparent)

但是好像不兼容 isrgb 这种类型

2. 自定义 postcss 插件

这个插件主要就是通过计算,把 color-mix 计算成为定值,然后应用上去以兼容老版本。

由于不想弄得太复杂精细,这里准备直接抽取其中变量作为css定值,不再考虑透明度的情况。 也就是

css 复制代码
color: color-mix(in srgb, var(--p-primary-color) calc(100% * 1), transparent)
转换为
color: var(--p-primary-color);

如果是这样那就简单多了。只需要通过正则提取出 color-mix 中的 var 变量就完成了。

ini 复制代码
export default (options = {}) => {
   return {
       postcssPlugin: 'color-mix',
       Declaration(decl) {
           // 跳过已处理过的节点
           if (decl.processed) return;

           const originalValue = decl.value;
           
           // 判断是否是 color-mix
           if (originalValue.indexOf('color-mix') < 0) {
               return;
           }

           console.log(`处理css: ${originalValue}`);

           const result =  replaceColorMix(originalValue)
           console.log(result)
           // 标记为已处理并替换
           decl.value = result;
           decl.processed = true;

       }
   };
};

// 提取出var变量替换
function replaceColorMix(cssCode) {
   const regex = /var(--[\w-]+)/;
   const match = cssCode.match(regex);
   if (match) {
       return match[0]
   } else {
       return cssCode
   }
}

export const postcss = true;

这样就直接兼容了之前浏览器了

相关推荐
milanleon26 分钟前
使用Spring Security进行登录认证
java·前端·spring
excel28 分钟前
🚀 从零开始:如何从 GPTsAPI.net 申请 API Key 并打造自己的 AI 服务
前端
期待のcode1 小时前
@RequestBody的伪表单提交场景
java·前端·vue.js·后端
栀秋6661 小时前
防抖 vs 节流:从百度搜索到京东电商,看前端性能优化的“节奏哲学”
前端·javascript
一颗烂土豆1 小时前
vfit.js v2.0.0 发布:精简、语义化与核心重构 🎉
前端·vue.js·响应式设计
有意义1 小时前
深入防抖与节流:从闭包原理到性能优化实战
前端·javascript·面试
可观测性用观测云2 小时前
网站/接口可用性拨测最佳实践
前端
2503_928411562 小时前
12.26 小程序问题和解决
前端·javascript·微信小程序·小程序
灼华_2 小时前
超详细 Vue CLI 移动端预览插件实战:支持本地/TPGZ/NPM/Git 多场景使用(小白零基础入门)
前端
借个火er2 小时前
npm/yarn/pnpm 原理与选型指南
前端