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

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

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

一、颜色函数

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

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

相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 "小贱贱"韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...