css函数

一、 🔢 数值/长度计算

函数 说明 示例
calc() 动态计算长度、百分比、数值等 width: calc(100% - 40px);
min() 取多个值中的最小值 width: min(50%, 300px);
max() 取多个值中的最大值 padding: max(10px, 2vw);
clamp() 设置一个值在最小和最大之间 font-size: clamp(16px, 4vw, 24px);

1.clamp()

把一个值的范围,"夹"在一个最大值和一个最小值之间

语法:
复制代码
width: clamp(最小值, 理想值, 最大值);
例:
javascript 复制代码
h1 { font-size: 16px; }
@media (min-width: 768px) { h1 { font-size: 24px; } }
@media (min-width: 1200px) { h1 { font-size: 32px; } }

变为:


h1 {
  /* 最小值是16px,
    理想值是视口宽度的4%,
    最大值是32px。
  */
  font-size: clamp(16px, 4vw, 32px);
}

二、progress()

计算某个数值在一个范围内的"进度比例"

  • 当当前值小于或等于开始值时,返回0
  • 当当前值大于或等于结束值时,返回1
  • 当当前值在两者之间时,返回按比例计算的小数
    • 计算公式是:(当前值 - 开始值) ÷ (结束值 - 开始值)

语法:

javascript 复制代码
progress(<当前值>, <开始值>, <结束值>)

例:

复制代码
h1 {
  /* 窗口宽度在480px到1200px之间时,字体大小从2rem渐变到3rem */
  font-size: calc(2rem + progress(100vw, 480px, 1200px) * 1rem);
}

三、 🎨 颜色函数

函数 说明 示例
rgb(r, g, b) / rgba(r, g, b, a) 红绿蓝颜色 color: rgb(255, 0, 0);
hsl(h, s, l) / hsla(h, s, l, a) 色相-饱和度-亮度 background: hsl(120, 100%, 50%);
hwb() 色相-白度-黑度(较新) color: hwb(200 50% 20%);
color-mix() 混合两种颜色(现代浏览器) background: color-mix(in srgb, red 30%, blue);
lab(), lch() 基于人眼感知的颜色空间 color: lab(70% 20 30);

1.color-mix()

复制代码
<el-button style="background-color: color-mix(in srgb, red 50%,blue 50%)">123</el-button>

四. 🌀 变换函数(Transform)

用于 transform 属性:

复制代码
.element {
  transform: 
    translateX(100px)     /* 平移 */
    rotate(45deg)         /* 旋转 */
    scale(1.2)            /* 缩放 */
    skew(10deg)           /* 倾斜 */
    matrix(1,0,0,1,50,50);/* 矩阵变换 */
}

五、 🖼️ 图像/滤镜函数

函数 说明 示例
url() 引用资源 background: url(bg.png);
linear-gradient() 线性渐变 background: linear-gradient(to right, red, blue);
radial-gradient() 径向渐变 background: radial-gradient(circle, red, yellow);
conic-gradient() 圆锥渐变 background: conic-gradient(red, green, blue);
blur(), grayscale(), opacity() 滤镜效果 filter: blur(5px) grayscale(100%);

六、 📐 其他实用函数

函数 说明 示例
var(--name) 使用 CSS 自定义属性(变量) color: var(--primary-color);
attr() 获取 HTML 属性值(常用于 content content: attr(data-label);
counter() 计数器(用于自动编号) content: counter(section) ".";
相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea5 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd6 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌7 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈7 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫7 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝7 小时前
svg图片
前端·css·学习·html·css3
王夏奇7 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰8 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong238 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习