百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

CSS中常用到的函数属性笔记

myzbx 2025-03-13 18:18 13 浏览

一、颜色函数

1. rgb()/ rgba()

  • 语法rgb(red, green, blue)rgba(red, green, blue, alpha)
    • red, green, blue: 0-255 的整数或 0%-100% 的百分比。
    • alpha: 0(透明)到 1(不透明)的小数。
  • 示例
color: rgb(255 0 0); /* 红色(CSS4+ 空格分隔语法) */
background: rgba(0 255 0 / 0.5); /* 半透明绿色(CSS4+ 简写) */
  • 注意
    • CSS4 支持省略逗号(用空格分隔),并支持 rgba() 简写为 / 语法(如 rgb(0 255 0 / 50%))。

2. hsl()/ hsla()

  • 语法hsl(hue, saturation%, lightness%)hsla(hue, saturation%, lightness%, alpha)
    • hue: 0-360 的色相角度(0=红,120=绿,240=蓝)。
    • saturation%: 0%(灰)到 100%(鲜艳)。
    • lightness%: 0%(黑)到 100%(白)。
  • 示例
background: hsl(270 80% 50% / 0.8); /* 紫色带透明度 */
  • 应用场景:更直观地调整颜色(如动态主题色)。

3. 现代颜色函数(CSS Color Level 4+)

  • lab():基于人类视觉的均匀颜色空间(Lightness, a轴, b轴)。
  • lch():类似 lab(),但用色度(Chroma)和色相角(Hue)。
  • oklab() / oklch():优化后的颜色空间,更符合人眼感知。
  • 示例
color: oklch(70% 0.3 270); /* 亮蓝色 */
  • 注意:部分浏览器需开启实验性支持(如 Safari)。

二、渐变函数

1. linear-gradient()

  • 语法linear-gradient([角度或方向], color-stop1, color-stop2, ...)
    • 方向:to top45deg(默认 to bottom)。
    • 颜色停靠点:yellow 20%(颜色 + 位置)。
  • 示例
background: linear-gradient(
 to right, 
 red 0%, 
 orange 50%, 
 yellow 100%
); /* 水平渐变 */
  • 技巧:用透明色创建叠加效果:
background: linear-gradient(rgba(0,0,0,0.5), transparent);

2. radial-gradient()

  • 语法radial-gradient([形状] [at 位置], color-stop1, color-stop2, ...)
    • 形状:circleellipse(默认)。
    • 位置:at center(默认)、at top left
  • 示例
background: radial-gradient(
 circle at 20% 80%, 
 #ff0000, 
 #0000ff
); /* 从左上角扩散的圆形渐变 */

3. conic-gradient()

  • 语法conic-gradient([起点角度 at 中心], color-stop1, color-stop2, ...)
    • 起点角度:默认从 12 点方向开始。
    • 示例(饼图):
background: conic-gradient(
 red 0deg 90deg, 
 green 90deg 180deg, 
 blue 180deg
);

三、布局与计算函数

1. calc()

  • 语法calc(数学表达式)
    • 支持 +, -, *, /,注意乘除需有单位类型一致(如 100% - 20px 有效)。
  • 示例
.container {
 width: calc(100vw - 40px); /* 视口宽度减去边距 */
 gap: calc(1rem * 0.5); /* 0.5rem 间距 */
}
  • 注意:避免复杂嵌套(可能影响性能)。

2. min(), max(), clamp()

  • 语法
    • min(value1, value2, ...):取最小值。
    • max(value1, value2, ...):取最大值。
    • clamp(min, ideal, max):限制在 minmax 之间。
  • 示例
.responsive-box {
 width: min(90%, 1200px); /* 最大不超过 1200px */
 font-size: clamp(16px, 3vw, 24px); /* 动态字体大小 */
}

3. minmax()(Grid 布局)

  • 语法minmax(min-size, max-size)
    • 用于定义网格轨道的尺寸范围。
  • 示例
grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
/* 自适应列,最小 200px,最大等分剩余空间 */

四、变形与动画函数

1. transform函数

  • 常用函数
    • translate(x, y):位移(支持 translateX(), translateY())。
    • rotate(angle):旋转(deg, rad, turn)。
    • scale(x, y):缩放(无单位数值)。
    • skew(x-angle, y-angle):倾斜。
  • 组合使用
.box {
 transform: translate(50%, -50%) rotate(45deg) scale(1.2);
}

2. cubic-bezier()(动画时间函数)

  • 语法cubic-bezier(x1, y1, x2, y2)
    • 定义动画速度曲线,默认值 ease = cubic-bezier(0.25, 0.1, 0.25, 1)
    • 工具:通过 cubic-bezier.com 调试曲线。
  • 示例
transition: transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);

3. steps()(逐帧动画)

  • 语法steps(n, jump-term)
    • n:分割的帧数。
    • jump-termjump-start(立即跳转)、jump-end(结束跳转)。
  • 示例
animation: walk 1s steps(8) infinite;
/* 将动画分为 8 帧播放 */

五、滤镜函数(filter属性)

1. blur()

  • 语法blur(radius)
    • radius:模糊半径(如 5px)。
  • 示例
.blurred {
 filter: blur(2px);
}

2. drop-shadow()

  • 语法drop-shadow(offset-x offset-y blur-radius color)
    • 更智能的投影(支持透明区域)。
    • 对比 box-shadowbox-shadow 作用于盒子,drop-shadow 作用于内容轮廓。
  • 示例
filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.5));

3. 颜色调整滤镜

  • 函数
    • brightness(%):亮度(>100% 更亮)。
    • contrast(%):对比度。
    • grayscale(%):灰度化。
    • hue-rotate(deg):色相旋转。
  • 组合使用
filter: brightness(80%) contrast(120%) grayscale(20%);

六、其他核心函数

1. var()(CSS 变量)

  • 语法var(--variable-name, fallback-value)
    • 变量需定义在 :root 或元素上:
:root {
 --primary-color: #ff4757;
}
.text {
 color: var(--primary-color, red); /* 后备值为 red */
}

2. attr()(属性值引用)

  • 语法attr(data-attribute)
    • 常用于伪元素的 content
Hover me
div::after { content: attr(data-tooltip); }

3. url()(资源引用)

  • 语法url(path/to/resource)
    • 支持相对路径、绝对路径或 Base64:
background-image: url("...");

七、高级函数(实验性/未来特性)

1. 三角函数(CSS Values Level 4)

  • 函数sin(), cos(), tan(), asin(), acos(), atan(), atan2()
  • 示例
.wave {
 transform: translateY(calc(sin(0.25turn) * 100px));
}

2. math()函数

  • 语法math(表达式)
    • 支持更复杂的数学运算(需浏览器支持)。

最佳实践与注意事项

  1. 浏览器兼容性
  2. 使用 Can I Use 检查支持情况。
  3. 对实验性功能(如 color-mod())提供备用方案。
  4. 性能优化
  5. 避免过度使用 calc() 嵌套或复杂滤镜。
  6. 渐变和阴影在大量使用时可能影响渲染性能。
  7. 响应式设计
  8. 结合 clamp()min()/max() 实现动态布局。
  9. 使用 image-set() 适配高分辨率屏幕。

通过深入理解这些函数,可以更高效地实现复杂布局、动画和视觉效果,同时保持代码简洁和可维护性。

相关推荐

Django零基础速成指南:快速打造带用户系统的博客平台

#python##服务器##API##编程##学习#不是所有教程都值得你花时间!这篇实战指南将用5分钟带你解锁Django核心技能,手把手教你从零搭建一个具备用户注册登录、文章管理功能的完整...

iOS 17.0 Bootstrap 1.2.9 半越狱来啦!更新两点

这款Bootstrap半越狱工具终于更新,离上一次更新已相隔很久,现在推出1.2.9版本,主要为内置两点功能进行更新,也是提升半越狱的稳定性。如果你正在使用这款半越狱工具的,建议你更新。注意!...

iOS 16.x Bootstrap 1.2.3 发布,支持运行清理工具

本文主要讲Bootstrap半越狱工具更新相关内容。如果你是iOS16.0至16.6.1和17.0系统的,想体验半越狱的果粉,请继续往下看。--知识点科普--Bootstrap...

SpringBoot整合工作流引擎Acticiti系统,适用于ERP、OA系统

今日推荐:SpringBoot整合工作流引擎Acticiti的源码推荐理由:1、SpringBoot整合工作流引擎Acticiti系统2、实现了三级权限结构3、持久层使用了mybatis框架4、流程包...

SpringCloud自定义Bootstrap配置指南

在SpringCloud中自定义Bootstrap配置需要以下步骤,以确保在应用启动的早期阶段加载自定义配置:1.添加依赖(针对新版本SpringCloud)从SpringCloud2020...

Python使用Dash开发网页应用(三)(python网页开发教程)

PlotlyDash开发Web应用示例一个好的网页设计通常都需要编写css甚至js来定制前端内容,例如非常流行的bootstrap框架。我们既然想使用Dash来搭建web应用,很大的一个原因是不熟悉...

Oxygen XML Editor 27.1 中的新功能

OxygenXMLEditor27.1版是面向内容作者、开发者、合作者和出版商的行业领先工具包的增量版本。在27.1版本中,AIPositronAssistant得到了增强,包括用于...

【LLM-多模态】Mini-Gemini:挖掘多模态视觉语言模型的潜力

一、结论写在前面论文提出了Mini-Gemini,一个精简而强大的多模态VLM框架。Mini-Gemini的本质在于通过战略性框架设计、丰富的数据质量和扩展的功能范围,发掘VLM的潜在能力。其核心是补...

谐云课堂 | 一文详解分布式改造理论与实战

01微服务与分布式什么是分布式?首先,我们对上图提到的部分关键词进行讲解。单体,是指一个进程完成全部的后端处理;水平拆分,是同一个后端多环境部署,他们都处理相同的内容,使用反向代理来均衡负载,这种也叫...

基于Abaqus的手动挡换挡机构可靠性仿真

手动挡,也称手动变速器,英文全称为Manualtransmission,简称MT,即用手拨动换挡操纵总成才能改变变速器内的齿轮啮合位置,改变传动比,从而达到变速的目的。家用轿车主要采用软轴连接的换挡...

【pytorch】目标检测:彻底搞懂YOLOv5详解

YOLOv5是GlennJocher等人研发,它是Ultralytics公司的开源项目。YOLOv5根据参数量分为了n、s、m、l、x五种类型,其参数量依次上升,当然了其效果也是越来越好。从2020...

超实用!50个非常实用的PS快捷键命令大全分享

今天,给大家介绍50个非常实用的快捷键命令大全,大家伙都是设计师,关于软件使用那是越快越好啊。一、常用的热键组合1、图层混合模式快捷键:正常(Shift+Option+N),正片叠底(Shif...

Pohtoshop中深藏不露的小技巧(科目一考试技巧记忆口诀看完必过)

邢帅教育ps教程为大家总结了一些Pohtoshop中深藏不露的小技巧,可以帮助到大家在设计时减少不必要的麻烦,提高工作效率哦~~~1.设置网格线保持像素完美不在1:1分辨率下也能保持像素完美,可以...

Ganglia监控安装总结(监控安装工作总结)

一、ganglia简介:Ganglia是一个跨平台可扩展的,高性能计算系统下的分布式监控系统,如集群和网格。它是基于分层设计,它使用广泛的技术,如XML数据代表,便携数据传输,RRDtool用于数据...

谁说Adobe XD做不出好看的设计?那是你没搞懂这些功能

AdobeXD的美化栏具有将设计视图美化的功能,它能使界面设计和原型设计更漂亮、更吸引眼球。美化栏的7个功能包括竖线布局设计、横线布局设计、重复网格、图形大小和位置设置、响应式调整大小、文字美化以及...