您现在的位置是:网站首页> 编程资料编程资料
初步认识css自定义属性css自定义属性和聚光灯效果的实现最新Edge浏览器将支持CSS自定义属性深入解析CSS中的自定义属性css如何实现自定义更为美观的链接提示效果
2021-09-04
1021人已围观
简介 今天,CSS预处理器是Web开发的标准。 预处理器的一个主要优点是它们使您能够使用变量, 这有助于您避免复制和粘贴代码,并简化了开发和重构。今天通过本文给大家分享如何将CSS变量集成到CSS开发工作流程中,感兴趣的朋友跟随小编一起学习吧
今天,CSS预处理器是Web开发的标准。 预处理器的一个主要优点是它们使您能够使用变量, 这有助于您避免复制和粘贴代码,并简化了开发和重构。
在本文中,您将了解到如何将CSS变量集成到CSS开发工作流程中,这会使得样式表更易于维护和不重复性。
现在,让我开始吧!
1* css变量的语法
<1> 什么是css变量?
如果您使用过任何一种编程语言,那么您应该已经熟悉了变量的概念。 变量允许您存储和更新程序所需的值以便工作。
在CSS中使用变量的好处与在编程语言中使用变量的好处并没有太大的不同。
以下是规范对此的说法:
[Using CSS variables] makes it easier to read large files, as seemingly-arbitrary values now have informative names, and makes editing such files much easier and less error-prone, as one only has to change the value once, in the custom property, and the change will propagate to all uses of that variable automatically.
W3C Specification .
[使用CSS变量]可以更容易地读取大文件,因为看似任意的值现在具有信息性名称,并且使得编辑此类文件更容易且更不容易出错,因为只需要在自定义属性中更改一次值 ,这种更改将自动传播到所有使用该变量的地方。
<2>css自定义变量语法
要声明变量而不是常用的CSS属性(如颜色或填充),只需提供以 - - 开头的自定义命名属性:
.box{ --box-color: #4d4e53; --box-padding: 0 10px; }属性的值可以是任何有效的CSS值:颜色,字符串,布局值,甚至是表达式。
以下是一些有用的自定义属性:
:root{ --main-color: #4d4e53; --main-bg: rgb(255, 255, 255); --logo-border-color: rebeccapurple; --header-height: 68px; --content-padding: 10px 20px; --base-line-height: 1.428571429; --transition-duration: .35s; --external-link: "external link"; --margin-top: calc(2vh + 20px); /* Valid CSS custom properties can be reused later in, say, JavaScript. */ --foo: if(x > 5) this.width = 10; }如果您不确定 :root,在HTML中它与html相同但具有更高的特异性,相当于全局变量。
<3> css变量的使用
var() 函数
您要通过 var() 这个 css 函数来使用 css 变量,将 css 变量名传入这个函数:
.box{ --box-color:#4d4e53; --box-padding: 0 10px; padding: var(--box-padding); } .box div{ color: var(--box-color); }var() 函数的语法是:
var([, ]? )
方法的第一个参数是要替换的自定义属性的名称。函数的可选第二个参数用作回退值。如果第一个参数引用的自定义属性无效,则该函数将使用第二个值。
如果您不确定是否已定义自定义属性并且想要提供用作回退的值,则可以执行此操作。
例如:
color: var(--foo, red, blue); //将red, blue同时指定为回退值;即是说任何在第一个逗号之后到函数结尾前的值都会被考虑为回退值。
padding: var(--box-padding, var(--main-padding));
calc()函数
由于我们习惯使用预处理器和其他语言,我们希望在处理变量时能够使用基本运算符。 为此,CSS提供了一个calc()函数,它使浏览器在对自定义属性的值进行任何更改后重新计算表达式:
:root{ --indent-size: 10px; --indent-xl: calc(2*var(--indent-size)); --indent-l: calc(var(--indent-size) + 2px); --indent-s: calc(var(--indent-size) - 2px); --indent-xs: calc(var(--indent-size)/2); }如果您尝试使用无单位值,则使用calc()函数可以带来很大的方便:
:root{ --spacer: 10; } .box{ padding: var(--spacer)px 0; /* DOESN'T work */ padding: calc(var(--spacer)*1px) 0; /* WORKS */ }css自定义属性的scop
自定义属性也遵守CSS层叠规则。
2* 利用js使用css自定义属性
假设您有一个名为 --left-pos 的 CSS 变量,其值为 100px,范围为 CSS 文档中的 .sidebar 类:
.sidebar { --left-pos: 100px; }可以通过如下方式获取 --left-pos 的值:
const sidebarElement = document.querySelector('.sidebar'); const cssStyles = getComputedStyle(sidebarElement); const cssVal = String(cssStyles.getPropertyValue('--left-pos')).trim(); console.log(cssVal); //100px设置css属性值:
sidebarElement.style.setProperty('--left-pos', '200px');3* css 变量和预处理变量有什么不同?
在样式化网站时,您可能通过使用Sass和Less等预处理器来使得变量的更具有灵活性。
预处理器允许您设置变量,并在函数,循环,数学运算等中使用它们。这是否意味着CSS变量无关紧要?
不完全是,主要是因为CSS变量与预处理器变量不同。
差异源于CSS变量是在浏览器中运行的真正的CSS属性,而预处理器变量需要被编译成常规CSS代码,因此浏览器对它们一无所知。
这意味着您可以更新样式表文档中的CSS变量,内联样式属性和SVG表示属性,或者选择使用JavaScript 动态 操作它们。对于 CSS 自定义属性的修改,会立马传递到使用到他的地方,而预处理器则无法完成这种行为,因为他们是提前已经编译好了的!
这并不是说你需要在一个或另一个之间做出选择:没有什么能阻止你利用CSS和预处理器变量一起工作的超能力。
总结
以上所述是小编给大家介绍的初步认识css自定义属性,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
相关内容
- 详解CSS 去掉inline-block元素间隙的几种方法 快速解决css使用@keyframes加载图片首次循环时出现白色间隙问题(闪屏)CSS图片下面有间隙的6种解决方案css几种解决inline-block间隙的方案(整理)css解决display:inline-block;产生的缝隙(间隙)的方法详解CSS清除图片下几像素空白间隙的方法
- 详解Html/CSS中的符号学CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- css 如何清除浮动的示例代码CSS 清除浮动与BFC的方法css overflow: hidden 的用法(溢出隐藏及清除浮动)CSS实现元素浮动和清除浮动的方法Css实现清除浮动的方法汇总什么是BFC? CSS 使用伪元素清除浮动的方法轻松搞懂CSS浮动与清除浮动图文详解CSS清楚浮动clear:both的实例代码
- 使用CSS改变图片颜色的100种方法(值得收藏)
- 纯CSS表头固定的实现代码CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS 、JS实现浪漫流星雨动画CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS未知高度垂直居中的实现CSS实现垂直居中的几种方法小结CSS实现垂直居中的七个方法实例代码详解css两种垂直居中对齐解决方案(小结)css实现元素垂直居中的常用方法(总结)利用css样式实现表格中字体垂直居中的方法
- CSS多级菜单的实现代码纯css实现多级折叠菜单折叠树效果
- css文本两端对齐的实现代码css两端对齐之div+css布局实现2端对齐的4种方法总结css 文本两端对齐应用实例
- 使用CSS属性选择器来拼接HTML的DNA的方法盘点CSS Selectors Level4中新增的选择器css选择器设置标签样式的实例代码CSS中的属性选择符和结构化伪类CSS first-chjld伪类属性匹配一个序列的第一个元素css对边框的属性控制和链接的伪类选择器-CSS教程-网页制作-网页教学网css选择器四大类:基本、组合、属性、伪类
