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) ".";
相关推荐
深耕AI18 分钟前
【wordpress系列教程】05 文章分类与标签
前端
michael_ouyang35 分钟前
WebSocket 鉴权方案选型与 Electron 应用的最佳实践
前端·websocket·网络协议·electron
xixixin_42 分钟前
【vue】中字符串与数组转换:为何首选 Computed 而非 Methods?
前端·javascript·vue.js
Sylvia33.1 小时前
网球/羽毛球数据API:专业赛事数据服务的技术实现
java·前端·websocket·json
向下的大树1 小时前
VUE父子组件传参中的触发时机问题:异步场景下的解决方案
前端·javascript·vue.js
英俊潇洒美少年1 小时前
vue2中使用节流防抖函数时,使用的vue状态始终是初始化的数据
前端·javascript·vue.js
棒棒的唐1 小时前
适合小程序使用的将对象数组转换为参数字符串方法
前端·javascript·小程序
博客zhu虎康2 小时前
音频视频处理:前端直播流播放 flv
前端
一位搞嵌入式的 genius2 小时前
深入理解 JavaScript 原型与继承:从基础到进阶
开发语言·前端·javascript
董世昌412 小时前
深度解析var、let、const的区别与最佳使用场景
开发语言·前端·javascript