CSS中的变量给了我们诸多优点:方便、代码重用、更可靠的代码库和提升防错能力。
示例
- :root {
- --base-font-size: 16px;
- --link-color: #6495ed;
- }
- p {
- font-size: var( --base-font-size );
- }
- a {
- font-size: var( --base-font-size );
- color: var( --link-color );
- }
基础
当使用CSS变量时,你应该了解的三个主要组成:
自定义属性
var()函数
:root伪类
自定义属性
你已经知道了一些CSS的标准属性,如color,margin,width和font-size。
下面的示例使用了CSS的color属性:
- body {
- color: #000000; /* The "color" CSS property */
- }
自定义属性仅意味着我们(创建CSS文件的人)去定义属性的名字。
为了自定义一个属性名,我们需要用--作为前缀。
如果我们要创建一个值为黑色的、名为text-color的自定义属性,可以这样做:
- :root {
- --text-color: #000000; /* A custom property named "text-color" */
- }
var()函数
为了应用自定义属性,需要利用var()函数,否则浏览器不知道他们代表什么。
如果想要在p、h1和h2中的样式中使用--text-color,可以这样使用var()函数:
- :root {
- --text-color: #000000;
- }
- p {
- color: var( --text-color );
- font-size: 16px;
- }
- h1 {
- color: var( --text-color );
- font-size: 42px;
- }
- h2 {
- color: var( --text-color );
- font-size: 36px;
- }
其等价于:
CSS Code复制内容到剪贴板- p {
- color: #000000;
- font-size: 16px;
- }
- h1 {
- color: #000000;
- font-size: 42px;
- }
- h2 {
- color: #000000;
- font-size: 36px;
- }
:root伪类
我们需要一个地方来放置自定义属性。虽然可以在任何样式规则中指定自定义属性,但到处定义属性并不是一个好主意,这对CSS的可维护性和可阅读性是一个挑战。
:root 伪类代表了HTML文档的根元素,这是一个放置自定义属性的好位置,因为我们可以通过其他更具特异性的选择器来覆盖自定义属性值。
CSS变量的好处
可维护性
在一个Web开发项目中,我们经常重复使用一个特定的CSS属性值:
CSS Code复制内容到剪贴板- h1 {
- margin-bottom: 20px;
- font-size: 42px;
- line-height: 120%;
- color: gray;
- }
- p {
- margin-bottom: 20px;
- font-size: 18px;
- line-height: 120%;
- color: gray;
- }
- img {
- margin-bottom: 20px;
- border: 1px solid gray;
- }
- .callout {
- margin-bottom: 20px;
- border: 3px solid gray;
- border-radius: 5px;
- }
当需要改变某些属性值时,问题就会暴露出来了。
如果我们手动的改变属性值,尤其是当CSS文件很大时,不仅会花费大量时间,还可能会范一些错误。同样的,如果我们执行一个批处理查找和替换,就可能会无意中影响其他样式规则。
我们可以使用CSS变量重写:
- :root {
- --base-bottombottom-margin: 20px;
- --base-line-height: 120%;
- --text-color: gray;
- }
- h1 {
- margin-bottom: var( --base-bottombottom-margin );
- font-size: 42px;
- line-height: var( --base-line-height );
- color: var( --text-color );
- }
- p {
- margin-bottom: var( --base-bottombottom-margin );
- font-size: 18px;
- line-height: var( --base-line-height );
- color: var( --text-color );
- }
- img {
- margin-bottom: var( --base-bottombottom-margin );
- border: 1px solid gray;
- }
- .callout {
- margin-bottom: var( --base-bottombottom-margin );
- border: 1px solid gray;
- border-radius: 5px;
- color: var( --text-color );
- }
假设你现在的客户说由于文本颜色太亮,导致文本难以阅读,想要改变文本颜色,此时,我们只需要更新一行CSS规则:
CSS Code复制内容到剪贴板- --text-color: black;
提高CSS的可读性
自定义属性会使样式表更加易读,也会使CSS属性声明更有语义。
将这个声明
- background-color: yellow;
和下面的声明比较一下
CSS Code复制内容到剪贴板- background-color: var( --highlight-color );
- font-size: var( --base-font-size );
像yellow和18px一类的属性值并没有给我们任何有用的上下文信息,但是当我们阅读如--base-font-size和--highlight-color一样的属性名时,即便在其他人的代码,我们都能马上知道这个属性值是在做什么。
要注意的事
大小写敏感
自定义属性是大小写敏感的(和普通的CSS规则不一样)
CSS Code复制内容到剪贴板- :root {
- --main-bg-color: green;
- --MAIN-BG-COLOR: RED;
- }
- .box {
- background-color: var( --main-bg-color ); /* green background */
- }
- .circle {
- BACKGROUND-COLOR: VAR(--MAIN-BG-COLOR ); /* red background */
- border-radius: 9999em;
- }
- .box,
- .circle {
- height: 100px;
- width: 100px;
- margin-top: 25px;
- box-sizing: padding-box;
- padding-top: 40px;
- text-align: center;
- }
自定义属性值的解析
当重复声明自定义属性时,其赋值遵循通常的CSS层叠和继承规则。例如下面的示例:
HTML
- <body>
- <div class="container">
- <a href="">Link</a>
- </div>
- </body>
CSS
CSS Code复制内容到剪贴板- :root {
- --highlight-color: yellow;
- }
- body {
- --highlight-color: green;
- }
- .container {
- --highlight-color: red;
- }
- a {
- color: var( --highlight-color );
- }
当移除.container规则时,链接的颜色值将是green。
回退值
当使用var()函数时,可以分配一个回退的属性值,其作为一个额外参数和第一个参数用,隔开。看下面的示例:
HTML
- <div class="box">A Box</div>
CSS
CSS Code复制内容到剪贴板- div {
- --container-bg-color: black;
- }
- .box {
- width: 100px;
- height: 100px;
- padding-top: 40px;
- box-sizing: padding-box;
- background-color: var( --container-bf-color, red );
- color: white;
- text-align: center;
- }
因为给var()传递了一个回退值参数,所以div的背景色最中被渲染成红色。
无效值
谨防给CSS属性分配错误类型的值。
在下面的示例中,由于自定义属性--small-button被赋予一个长度单位,它被用在.small-button样式中是无效的(译者注:因为color的属性类型值出错)
- :root {
- --small-button: 200px;
- }
- .small-button {
- color: var(--small-button);
- }
避免这种情况的一个好方式是想出具有描述性的自定义属性名称。例如将上面的自定义属性命名为--small-button-width
浏览器对CSS变量的支持
CSS,变量
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]