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

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

zhezhongyun 2025-04-24 10:32 7 浏览

一、颜色函数

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
<div data-tooltip="提示内容">Hover me</div>div::after {
 content: attr(data-tooltip);
}

3. url()(资源引用)

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

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

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() 适配高分辨率屏幕。

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

相关推荐

JPA实体类注解,看这篇就全会了

基本注解@Entity标注于实体类声明语句之前,指出该Java类为实体类,将映射到指定的数据库表。name(可选):实体名称。缺省为实体类的非限定名称。该名称用于引用查询中的实体。不与@Tab...

Dify教程02 - Dify+Deepseek零代码赋能,普通人也能开发AI应用

开始今天的教程之前,先解决昨天遇到的一个问题,docker安装Dify的时候有个报错,进入Dify面板的时候会出现“InternalServerError”的提示,log日志报错:S3_USE_A...

用离散标记重塑人体姿态:VQ-VAE实现关键点组合关系编码

在人体姿态估计领域,传统方法通常将关键点作为基本处理单元,这些关键点在人体骨架结构上代表关节位置(如肘部、膝盖和头部)的空间坐标。现有模型对这些关键点的预测主要采用两种范式:直接通过坐标回归或间接通过...

B 客户端流RPC (clientstream Client Stream)

客户端编写一系列消息并将其发送到服务器,同样使用提供的流。一旦客户端写完消息,它就等待服务器读取消息并返回响应gRPC再次保证了单个RPC调用中的消息排序在客户端流RPC模式中,客户端会发送多个请...

我的模型我做主02——训练自己的大模型:简易入门指南

模型训练往往需要较高的配置,为了满足友友们的好奇心,这里我们不要内存,不要gpu,用最简单的方式,让大家感受一下什么是模型训练。基于你的硬件配置,我们可以设计一个完全在CPU上运行的简易模型训练方案。...

开源项目MessageNest打造个性化消息推送平台多种通知方式

今天介绍一个开源项目,MessageNest-可以打造个性化消息推送平台,整合邮件、钉钉、企业微信等多种通知方式。定制你的消息,让通知方式更灵活多样。开源地址:https://github.c...

使用投机规则API加快页面加载速度

当今的网络用户要求快速导航,从一个页面移动到另一个页面时应尽量减少延迟。投机规则应用程序接口(SpeculationRulesAPI)的出现改变了网络应用程序接口(WebAPI)领域的游戏规则。...

JSONP安全攻防技术

关于JSONPJSONP全称是JSONwithPadding,是基于JSON格式的为解决跨域请求资源而产生的解决方案。它的基本原理是利用HTML的元素标签,远程调用JSON文件来实现数据传递。如果...

大数据Doris(六):编译 Doris遇到的问题

编译Doris遇到的问题一、js_generator.cc:(.text+0xfc3c):undefinedreferenceto`well_known_types_js’查找Doris...

网页内嵌PDF获取的办法

最近女王大人为了通过某认证考试,交了2000RMB,官方居然没有给线下教材资料,直接给的是在线教材,教材是PDF的但是是内嵌在网页内,可惜却没有给具体的PDF地址,无法下载,看到女王大人一点点的截图保...

印度女孩被邻居家客人性骚扰,父亲上门警告,反被围殴致死

微信的规则进行了调整希望大家看完故事多点“在看”,喜欢的话也点个分享和赞这样事儿君的推送才能继续出现在你的订阅列表里才能继续跟大家分享每个开怀大笑或拍案惊奇的好故事啦~话说只要稍微关注新闻的人,应该...

下周重要财经数据日程一览 (1229-0103)

下周焦点全球制造业PMI美国消费者信心指数美国首申失业救济人数值得注意的是,下周一希腊还将举行第三轮总统选举需要谷歌日历同步及部分智能手机(安卓,iPhone)同步日历功能的朋友请点击此链接,数据公布...

PyTorch 深度学习实战(38):注意力机制全面解析

在上一篇文章中,我们探讨了分布式训练实战。本文将深入解析注意力机制的完整发展历程,从最初的Seq2Seq模型到革命性的Transformer架构。我们将使用PyTorch实现2个关键阶段的注意力机制变...

聊聊Spring AI的EmbeddingModel

序本文主要研究一下SpringAI的EmbeddingModelEmbeddingModelspring-ai-core/src/main/java/org/springframework/ai/e...

前端分享-少年了解过iframe么

iframe就像是HTML的「内嵌画布」,允许在页面中加载独立网页,如同在画布上叠加另一幅动态画卷。核心特性包括:独立上下文:每个iframe都拥有独立的DOM/CSS/JS环境(类似浏...