声明你的第一个css变量

声明你的第一个css变量

刚开始的“css变量”,经扩展之后,称为“css自定义属性”。当各种预处理器满天飞的时候,css变量已经开始渐渐普及在特定的应用场景,css变量确实发挥了很大的作用。

(学习视频分享:css视频教程)

此外,与一些 CSS 预处理器不同的是,CSS 变量实际上是 DOM 的一部分,这对于开发有极大的好处。

为什么学习 CSS 变量?

立即学习“前端免费学习笔记(深入)”;

关于为什么在 CSS 中使用变量有很多理由,其中最主要的一点就是它减少了样式代码的重复。

}IXFSE)QS(P_RCD}6_7_(HL.png

以这段代码为例,像我们下面这样为 #ffeead 颜色创建一个变量会比机械地重复它好得多:

F(2`6J)_XGXU~J)6PXC~PFB.png

这样一来你的代码不仅仅是变得更加可读,而且也为你将来想要做出改变提供了更多的灵活性。

虽然这一功能 SASS 和 LESS 早在几年前就实现了,但 CSS 变量还是有很多亮点:

它不需要经过任何转译步骤,因为它是浏览器原生支持的。所以你不需要像使用 SASS 和 LESS 那样,你不需要任何设置就能直接书写这样的代码。

它是 DOM 的一部分,这给我们带来了极大的便利,这一点我后面会在文章中进行阐述。

那么我们开始吧!

声明你的第一个 CSS 变量

在声明一个变量之前,首先你要确定这个变量的作用域在哪,如果你想让它在全局生效,只需在:root伪类中定义它即可。它会匹配文档的根元素(通常是标签)。

由于变量是可继承的,所以你的整个 HTML 结构树都能使用这个变量,因为所有的 DOM 元素都是 节点的后代。

:root {  --main-color: #ff6f69;}

登录后复制

你可以像设置任何CSS属性一样声明一个变量。 但不同的是,变量必须以两个破折号开头。

而要获取到这个变量的值,需要使用 var() 函数,并将变量的名称作为参数传入。

#title {  color: var(--main-color);}

登录后复制

你的标题将被赋值 #ff6f69 的颜色。

1X5~NN94P(J5CB]{0X4V)NY.png

声明一个局部变量

你也可以创建局部变量,局部变量只能够被声明的元素及其子元素访问。一般当你想要仅在页面的某些特定部分使用这个变量时声明。

例如,假设你的页面中有个警告框,你想给它赋值一个特殊的颜色,而这个颜色在页面的其他部分又没有应用到。那么在这种情况下,就应该避免创建全局变量,使用局部变量就更为合理。

.alert {  --alert-color: #ff6f69;}

登录后复制

现在在其子元素中就能够使用这个变量了:

.alert p {  color: var(--alert-color);  border: 1px solid var(--alert-color);}

登录后复制

如果你尝试在页面其他位置使用变量 alert-color,是无效的,浏览器会忽略那一行 CSS 代码。

通过 CSS 变量更容易地实现响应式布局

CSS 变量的一大优势是它们可以访问 DOM ,这是 LESS 或 SASS 的变量所做不到的,因为它们会被编译为常规的 CSS 。

这意味着你可以根据屏幕的宽度来改变变量的值:

:root {  --main-font-size: 16px;}media all and (max-width: 600px) {  :root {    --main-font-size: 12px;  }}

登录后复制

仅仅通过这简单的四行代码,你就能改变你的应用在小屏幕上所显示的主字体大小,骚操作?

JavaScript 如何访问 CSS 变量

与 DOM 相结合的另一大优势是你可以通过 JavaScript访问到变量,甚至可以更新变量的值,例如基于交互的样式改变。如果你想让用户能够更改你的网站的样式(如调整字体大小),这将会是一个非常完美的解决方案。

让我们继续刚刚的例子,在 JavaScript 中获取 CSS 变量的值只需要三行代码。

var root = document.querySelector(':root');var rootStyles = getComputedStyle(root);var mainColor = rootStyles.getPropertyValue('--main-color');console.log(mainColor);  --> '#ffeead'

登录后复制

要更新 CSS 变量,只需在已声明变量的元素上调用 setProperty 方法,并将变量名称作为第一个参数,将新值作为第二个参数传入。

root.style.setProperty('--main-color', '#88d8b0')

登录后复制

main-color 属性会改变你的页面的整体外观,这让用户自定义网站的主题色变得极其简单。

浏览器支持

目前,全球网站流量的 77% 支持CSS变量,而美国已经接近90%。我们已经在 Scrimba.com 上使用 CSS 变量,因为我们的客户大多使用现代浏览器。

5K(KYL2W1_5@]9`W3@XXKOL.png

以上就是 CSS 变量的大概,希望你能有所收获。

相关推荐:css视频教程

以上就是声明你的第一个css变量的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2881214.html

(0)
上一篇 2025年3月10日 20:01:07
下一篇 2025年2月19日 13:44:35

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • margin和padding的区别是什么

    区别:margin是指从自身边框到另一个容器边框之间的距离,即容器外距离,是隔开元素与元素的间距;而padding是指自身边框到自身内部另一个容器边框之间的距离,即可容器内距离,是盒子边框与盒子内部元素的距离。 本文操作环境:宏基s40-5…

    2025年3月10日 编程技术
    200
  • first-child的作用是什么

    “:first-child”是css中的一个选择器,其作用是用于匹配其父元素中的第一个子元素;其语法格式是“指定子元素:first-child{css代码样式}”。 本文操作环境:宏基s40-51、hbuilderx.3.0.5&&…

    2025年3月10日
    200
  • 谈谈css中的栅格布局(图文)

    (学习视频分享:css视频教程) 栅格布局能将网页分成简单属性的行和列,CSS页面布局技术允许我们拾取网页中的元素,并且控制它们相对正常布局流、周边元素、父容器或者主视口/窗口的位置。 圣杯布局 圣杯布局是一种三列布局,两边定宽,中间自适应…

    2025年3月10日 编程技术
    200
  • css里图片和文字如何等高

    css里设置图片和文字等高的方法:1、添加css属性“vertical-align:middle;”;2、将图片和文字分别套上一个div,然后利用margin属性实现图片和文字等高效果即可。 本教程操作环境:windows7系统、css3版…

    2025年3月10日
    200
  • css框模型规定了什么作用

    css框模型规定了元素框处理元素内容、内边距、边框和外边距的方式;元素框的最内部分是实际的内容,直接包围内容的是内边距;内边距呈现了元素的背景,内边距的边缘是边框;边框以外是外边距,外边距默认是透明的,因此不会遮挡其后的任何元素。 本教程操…

    2025年3月10日
    200
  • css如何设置li的样式

    css设置li样式的方法:1、通过list-style-type属性定义li列表的项目符号;2、通过list-style-image属性实现使用图片代替项目符号;3、通过list-style属性综合设置li样式即可。 本教程操作环境:win…

    2025年3月10日
    200
  • none在css中表示什么意思

    none在css中表示令某个元素失效,常用于display、border、outline、list-style等属性中;如“display:none;”属性表示设置元素不显示,“border: none;”属性表示不显示元素的边框等。 本教…

    2025年3月10日
    200
  • CSS实现居中的几种方案(总结)

    本篇文章给大家介绍一下多个css居中方案。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 (学习视频分享:css视频教程) 水平居中 内联元素 要使内联元素(如链接,span 或img)居中,使用 text-align: …

    2025年3月10日 编程技术
    200
  • 详解CSS中的:placeholder-shown伪类

    (学习视频分享:css视频教程) 一般我们常见placeholder伪类选择器用来修改默认样式及文案,忽然发现placeholder-shown伪类选择器,比较官方的解释是 CSS伪类表示任何显示占位符文本的form元素。 简单来说就是当输…

    2025年3月10日 编程技术
    200
  • 使用CSS Flexbox构建网站标题

    在 CSS3 没有普及的时候,创建一个网站 header 是一项既可怕又困难的任务 ?。那时,Flexbox 还是个新东西,我们不得不使用老方法,比如 float和clearfix技术。今天,情况完全不同了,Flexbox 得到了广泛的支持…

    2025年3月10日 编程技术
    200

发表回复

登录后才能评论