color-mix让你秒变调色大神

你还在为写不同的颜色而发愁吗?一个按钮有很多种颜色,你怎么写?鼠标悬浮上去的颜色,禁用时的颜色,点击时的颜色,你都怎么写?然后还不止一种类型的按钮,primary, info, danger, warn, scuccess 这种常见类型的按钮,都需要写很多种颜色。

聪明的你可能会想到使用sass预处理器,它提供了darken和lighten函数。然而现在css已经支持了color-mix函数,它可以让你秒变调色大神。

基本语法

css 复制代码
color-mix(<color-interpolation-method>, <color>[<percentage>], <color>[<percentage>])

一学就会的调色魔法

color-mix()就像个调色盘,把两个颜色倒在一起搅和搅和:

css 复制代码
div {
  background-color: color-mix(in srgb, red 60%, blue);
}

下面就是60%红色和40%蓝色的混合结果

按钮主题色

element-plus/button 提供了自定义主题色的功能,通过color属性设置主题色,组件会自动生成不同状态下的颜色。而element-plus中是通过 @ctrl/tinycolor 库来实现的,它是一个非常强大的颜色处理库,支持多种颜色格式,包括RGB、HSL、HSV、HEX、HSB等。

现在我们来看看如何使用color-mix函数来实现自定义主题色。

css 复制代码
.btn {
  width: 100px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;

  --main-color: #626aef;
  background-color: var(--main-color);
  color: white;
  border: none;

  &:hover {
    background-color: color-mix(in srgb, var(--main-color) 80%, white);
  }

  &:disabled {
    background-color: color-mix(in srgb, var(--main-color) 50%, white);
  }

  &.plain {
    background-color: color-mix(in srgb, var(--main-color) 20%, white);
    color: var(--main-color);
    border: 1px solid color-mix(in srgb, var(--main-color) 70%, white);

    &:hover {
      background-color: var(--main-color);
      color: white;
      border: none;
    }

    &:disabled {
      background-color: color-mix(in srgb, var(--main-color) 10%, white);
      color: color-mix(in srgb, var(--main-color) 40%, white);
      border: 1px solid color-mix(in srgb, var(--main-color) 20%, white);
    }
  }
}

代码中的混合比例我就大概写了一下,实际功能开发可能需要根据设计稿来调整。这样完全使用css根据主色值,快速生成不同状态下的各种颜色了。有些渐变色的按钮也是可以的,只要使用color-mix生成好不同位置的颜色,然后使用linear-gradient函数生成渐变效果即可。

兼容性

主流浏览器都支持color-mix函数,包括Chrome、Firefox、Safari、Edge, Opera等。应该可以这么放心使用了


color-mix函数的第一个参数支持很多格式。本文中使用的是srgb,还支持lab, hsl等各种颜色格式。可以根据需要选择合适的颜色格式。具体的可以参考mdn文档。

相关推荐
橙子家6 小时前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
最新资讯动态7 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态7 小时前
游戏出海,从产品走向体系
前端
最新资讯动态7 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态7 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝9 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen9 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒10 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
徐小夕11 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
一份执念11 小时前
uni-app 小程序分包限制处理与主包体积优化实战
前端·微信小程序