网站首页 > 技术文章 正文
CSS 变量(正式术语称为 CSS 自定义属性),其行为与其他编程语言中的变量非常相似。可以用来将 CSS 文档中那些重复的特定值命名为变量。CSS 变量以两个破折号(--)为前缀(例如--my-color: black)来定义变量。
要访问变量,您可以使用该var()函数(例如color: var(--my-color))。CSS 变量对于在不同元素和组件之间共享样式非常有用。
最常见的用例之一是制作网站主题。CSS 变量在整个网站上创建公共的主题,并轻松将其换成不同的主题。这通常是将一个类应用于一个共同的祖先元素(例如<body>元素)来实现的。此示例演示了:root根元素中定义的全局变量,然后再body元素从其父级继承值:
/* 在根元素上定义公共的主题变量*/
:root {
--bg-color: #fff;
--main-color: #000;
--secondary-color: #222;
}
/*在body元素上使用这些变量 */
body {
background-color: var(--bg-color);
color: var(--main-color);
}
small {
color: var(--secondary-color);
}
/* 定义另一个暗黑主题,可以覆盖默认主题*/
body.dark {
--bg-color: #080808;
--main-color: #fff;
--secondary-color: #ccc;
}
另一个示例,在制作组件时定义不同的样式,比如下面按钮组件:
.btn {
--bg-color: #002299;
--text-color: #fff;
--highlight-color: #669900;
background-color: var(--bg-color);
color: var(--text-color);
}
/* .btn 按钮子元素使用 --highlight-color 颜色 */
.btn .highlight {
color: var(--highlight-color);
}
/* 定义警告按钮的样式, 覆盖默认变量 */
.btn-danger {
--bg-color: #dd4a68;
--text-color: #000;
--highlight-color: #990055;
}
最后,请记住在使用 CSS 变量时要注意事项:
- 您可以通过向var()函数提供第二个参数来定义备用值(例如var(--text-color, black),如果--text-color未定义时,默认为black)。
- CSS 变量区分大小写,因此请注意大小写。它们也可以在 HTML 内联样式中使用(例如<div style="--text-color: red">)。
- 您可以嵌套var()调用,使用另一个变量作为备用值(例如var(--main-color, var(--other-color)))。
- 也可以将它们传递给其他函数,例如calc()函数(例如calc(--width - 10px))。
- 甚至将一个变量分配给另一个变量(例如--text-color: var(--main-color))。
猜你喜欢
- 2025-01-06 CSS实现常见元素水平、垂直居中
- 2025-01-06 采用后端代码方式实现对Html元素封装与输出
- 2025-01-06 HTML页面基本结构和加载过程
- 2025-01-06 带你了解用5个div让你闯进弹性布局
- 2025-01-06 前端入门——浮动float
- 2025-01-06 简析JS中Document与CSS
- 2025-01-06 CSS样式优先级怎样划分?【CSS优先级规则】
- 2025-01-06 谷歌F12开发者工具面板解析操作
- 2025-01-06 这8个卡片设计方法,你还真不一定知道
- 2025-01-06 「CSS三种居中方案全解」CSS垂直居中常用方法集结
- 05-15总结雅虎前端性能优化技巧(16条)
- 05-15日常生活中吃雪莲果有养生功效也有危害
- 05-15API 安全之认证鉴权
- 05-15Chaosblade: 阿里一个超级牛逼的混沌实验实施工具
- 05-15膨来仙岛丨搞电竞的都是什么成分?
- 05-15大事全知晓!2022年新闻日历来了!
- 05-15你是有多久没看过麦田圈了?一篇文章全面回顾2015麦田圈季
- 05-15魔兽世界9.1 刻希亚寻找宝箱、稀有WA(转自nga)
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- js数组插入 (83)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)