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) ".";
相关推荐
霍理迪1 小时前
CSS盒模型布局规则
前端·javascript·css
千寻girling1 小时前
面试官: “ 说一下 JS 中什么是事件循环 ? ”
前端·javascript
程序员龙语1 小时前
CSS 高级选择器应用
前端·css
Cassie燁1 小时前
el-table源码解读2-2——createStore()初始化方法
前端·javascript·vue.js
程序员修心1 小时前
CSS文本样式全解析:11个核心属性详解
前端·css
旧梦吟2 小时前
脚本网站 开源项目
前端·web安全·网络安全·css3·html5
北极糊的狐2 小时前
按钮绑定事件达成跳转效果并将树结构id带入子页面形成参数完成查询功能并将返回的数据渲染到页面上2022.5.29
前端·javascript·vue.js
幽络源小助理2 小时前
幽络源二次元分享地址发布页源码(HTML) – 源码网免费分享
前端·html
全栈前端老曹2 小时前
【ReactNative】页面跳转与参数传递 - navigate、push 方法详解
前端·javascript·react native·react.js·页面跳转·移动端开发·页面导航
用泥种荷花3 小时前
【前端学习AI】Python环境搭建
前端