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

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

yund56 2025-04-11 20:28 14 浏览

一、颜色函数

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

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

相关推荐

如何在Office 中编辑 PDF?附详细化步骤

PDF很受欢迎,因为它能在不同的设备和操作系统上仍然保持原有格式。但是,这也意味着直接更改PDF文件比其他格式更难更复杂。值得庆幸的是,Microsoftoffice和UPDF帮你解决这一难题。一...

我的 Windows 装机必备软件清单

今天给大家分享下我的装机必备软件,都是用了好多年的软件神器。靠谱、好用、无广告,Windows电脑必备软件,收藏这一篇就够了!01.浏览器王者:Chromehttps://www.google.c...

Docnet Core 是一个轻量级、高性能的 .NET PDF 操作库

DocnetCore介绍DocnetCore是一个轻量级、高性能的.NETPDF操作库,依托于PDFium渲染引擎,提供强大的PDF文档解析、渲染、操作等功能。它完全支持.NET...

分享三款好用的PDF编辑软件,轻松处理PDF

作为一名需要经常和PDF文件打交道的工作者,我来分享一下几款好用的PDF编辑软件,并详细分析了它们的优缺点,希望能帮你找到合适的工具。1.AdobeAcrobatDC作为PDF格式的发明者,Ado...

PDF文档创建工具软件:novaPDF OEM 11.9 Build 432 for Windows

novaPDFOEM是一款实用高效的软件,从头开始设计,让您尽可能轻松地在应用程序中添加PDF打印功能。换句话说,这个实用程序是专门为应用程序开发人员设计的,可以直接在程序安装程序中集成为PDF打印...

线性表顺序存储结构求集合的并,交,补,差(源代码附上 超详细)

一:算法分析1)用数组A,B,C,E表示集合。假定A={1,3,4,5,6,7,9,10},  B={2,,3,4,7,8,10},E={1,2,3,4,5,6,7,8,9,10},  输入数组A...

分享一套SpringBoot开发博客系统源码,包含完整开发文档和视频

基本信息项目名称:eblog摘要:eblog是一个基于Springboot2.1.2开发的博客学习项目,为了让项目融合更多的知识点,达到学习目的,编写了详细的从0到1开发文档。主要学习包括:自定义Fr...

通达信指标合集〔源码齐全〕

很多朋友问到我哪款指标好用,这里我说一下,之所以有很多不同的指标是因为我们在针对不同的盘面情况的时候使用的指标是不同的,我给到的指标一般来讲就目前的环境来讲都是比较适合的,今天我就把我平时自己常用的指...

巅峰对决!Spring Boot VS .NET 6

SpringBoot和ASP.NETCore都是企业中流行的Web框架,对于喜欢C#的人会使用ASP.NETCore,而对于Java或Kotlin等基于JVM的语...

在asp.net core 中控制访问权限的方法

Intro#由于项目需要,需要在基于asp.netmvc的Web项目框架中做权限的控制,于是才有了这个权限控制组件,最初只是支持netframework,后来dotnetcore2.0...

ASP.NET是否无生存之地?

ASP.NET,这个已经很久的技术,总觉得已经被时代淘汰,我们公司是一个10人小公司,几个十年十五年的项目还是用ASP.NET开发的。这两年由于客户的需求变化,我们公司也顺势开始对这些项目重新开发,改...

Spring Boot + Vue.js 实现前后端分离(附源码)

作者:梁小生0101链接:juejin.im/post/5c622fb5e51d457f9f2c2381SpringBoot+Vue.js前后端涉及基本概念介绍,搭建记录,本文会列举出用到环...

ASP.NET Core 中的 Mapster 使用入门教程

在本文中,我们将学习如何在ASP.NETCore应用程序中使用Mapster。首先,我们将了解Mapster是什么以及如何将其安装到.NETCore应用程序中。然后,我们将在使用...

Asp.net常用方法及request和response-a

asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...

ASP.NET Core使用功能开关控制路由访问

前言在前面的文章,我们介绍了使用Middleware有条件地允许访问路由(《ASP.NETCore使用Middleware有条件地允许访问路由》)。而对于一些试验性的功能,我们并不希望用密码去控制是...