您现在的位置是:网站首页> 编程资料编程资料
CSS中关于变量的基本教程CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
2021-09-05
957人已围观
简介 这篇文章主要介绍了CSS中关于变量的基本教程,是CSS入门学习中的基础知识,需要的朋友可以参考下
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;
- }
其等价于:
- 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属性值:
- 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规则:
- --text-color: black;
提高CSS的可读性
自定义属性会使样式表更加易读,也会使CSS属性声明更有语义。
将这个声明
- background-color: yellow;
和下面的声明比较一下
- background-color: var( --highlight-color );
- font-size: var( --base-font-size );
像yellow和18px一类的属性值并没有给我们任何有用的上下文信息,但是当我们阅读如--base-font-size和--highlight-color一样的属性名时,即便在其他人的代码,我们都能马上知道这个属性值是在做什么。
要注意的事
大小写敏感
自定义属性是大小写敏感的(和普通的CSS规则不一样)
相关内容
- CSS3中的clip-path使用攻略CSS3 clip-path 用法介绍详解
- CSS中的伪元素简介通过CSS3的object-fit来调整图片适配尺寸的技巧简介CSS计数器counter()的用法简介简介CSS中的各种选择符Markdown.css样式简介CSS3 Columns分列式布局方法简介定义css设备类型-Media Queries图表简介及使用方法css3背景图片透明叠加属性cross-fade简介及用法实例
- CSS中的属性选择符和结构化伪类盘点CSS Selectors Level4中新增的选择器css选择器设置标签样式的实例代码使用CSS属性选择器来拼接HTML的DNA的方法CSS first-chjld伪类属性匹配一个序列的第一个元素css对边框的属性控制和链接的伪类选择器-CSS教程-网页制作-网页教学网css选择器四大类:基本、组合、属性、伪类
- 深入理解CSS中的UI伪类CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 详解CSS中的类和ID选择符CSS 类选择符和ID选择符的区别
- CSS中一些特殊的上下文选择符的使用CSS中的选择符实际使用指南解析css中的选择符命名简介CSS中的各种选择符
- CSS中的文本属性学习指南CSS中一些常用的文本属性整理CSS文本属性的使用方法css对于颜色和文本属性的控制-CSS教程-网页制作-网页教学网
- 详解CSS中的字体属性的使用CSS 字体属性font相关的用法CSS 表单元素不继承body的字体属性
- CSS中一些@规则的用法小结CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS注释的一些高级用法CSS条件注释详解(根据不同浏览器加载CSS)常用css样式属性大全(中文注释)css注释和html注释用法及应用范围介绍
点击排行
本栏推荐
