详细介绍css3中的变量使用

article/2025/8/23 11:22:30

CSS3新功能之变量:variables

css3为我们提供了一个强大的功能自定义属性,也就是变量,他能让我们更改色系、皮肤、自适配变得简单。我们只需要更改一些我们事先定义好的变量就可以轻松实现各种效果。特别是我们在开发大型项目的时候有多处使用相同的值来表示,这个时候我们就可以吧相同的属性值抽离出来定义成变量方便我们后期统一修改

变量声明

/* 定义全局变量 */
:root{--navColor: #c00;--navPadding: 10px;
}/* 定义局部变量 */
selector{--nameFont: italic small-caps 400 12px / 20px '微软雅黑';--boxBorder: 2px solid rgba(0, 0, 0, .2);
}
/* 使用var函数定义变量 */
selector{--borderWidth: 8px;--borderColor: red;--borderStyle: solid;--border: var(--borderWidth) var(--borderColor) var(--borderStyle);border: var(--border);
}

从上面可以看出在css中定义变量和声明一条css规则差不多只是前边使用--两个中横线后边跟着变量名。上面的代码:root中定义的变量为全局变量可以在任何元素中使用;selector中定义的变量为局部变量,只能在选择器范围内,和他的子元素中使用。

需要注意:

  1. css中的变量名是区分大小写的--navColor--navcolor是两个不同的变量;
  2. 定义变量的时候:号和;中间是一个整体,整体是变量的值;
  3. 变量值也就是css的规则值,任何规则值都可以存入变量,并且变量值不用加引号;

兼容性:
在这里插入图片描述

查看兼容详情

变量使用

要想使用上边我们定义的变量,就要用到var()函数

语法:

  var( <custom-variable-name> , <declaration-value>? )

参数说明:

  1. custom-variable-name:必填,表示我们定义的变量名;
  2. declaration-value:可选,后补值,当自定义变量值不存在的情况下将使用这个值,他会将把自定义变量名后边的所有参数看成一个整体,所以这个值可以包含逗号,、空格、括号()等css有效的规则值,他不能使用自定义变量名,不能有回车换行,不能有;

实例:

.nav{color: var(--navColor);padding: var(--navPadding);
}
selector{font: var(--nameFont, normal 700 16px/ 30px '黑体');border: var(--boxBorder, 1px solid #c00);
}

兼容性:
在这里插入图片描述

查看兼容详情

变量的作用域

上面我们提到过css的变量是有它的作用域的,在全局和布局同时定义了一个变量,会优先应用局部作用域。

代码说明:

<div class="div-1">这里显示绿色文字</div>
<div class="div-2">这里显示红色文字</div>
<div class="div-3" style="--fontColor:blue;">这里显示蓝色文字</div>
<style>
:root{--fontColor: red;
}
.div-1{--fontColor: green;/* 这里将应用绿色的文字样式,也就是自己定义的局部变量 */color: var(--fontColor);
}
.div-2{/* 这里将应用红色的文字样式,也就是根目录的变量 */color: var(--fontColor);
}
.div-3{/* 这里将应用蓝色的文字样式,也就是元素中style行内定义的变量 */color: var(--fontColor);
}
</style>

变量的优先级

css中应用变量时的优先级和css定义用选择器定义属性优先级差不多

代码说明:

<div class="box-1" id="box"><span class="span">这里显示绿色文字<span>
</div>
<style>
:root{--bgColor: red;
}
#box{--bgColor: blue;
}
.box-1{--bgColor: green;
}
.span{--bgColor: purple;
}
.box-1{/* 这里将应用蓝色的背景样式,也就是通过id定义的变量 */background-color: var(--bgColor);
}
.span{/* 这里将应用自色的背景样式,也就是通过自己class名定义的变量 */background-color: var(--bgColor);
}
</style>

从上边代码可以看出,css获取变量和css的样式优先级一样,顺序是:!important > style="" > #id > .class > tagName > :root; 但是需要注意的是这里的span是先找自己定义作用域下的变量,如果没有才找父级作用域的变量,上边代码span自身定义的有变量,所以背景就是紫色。

案例演示:https://codepen.io/qwguo88/full/eYpXGGQ

javascript中操作变量

css3中的变量我们也可以使用javascript来获取和操作它

// 获取行内样式的变量名
element.style.getPropertyValue("--variableName");// 获取样式表里定义的变量
getComputedStyle(element).getPropertyValue("--variableName");// 设置变量的值
element.style.setProperty("--variableName", value);

检测浏览器支持情况

我们可以通过css语法和javascript语法来检测浏览器是否支持css变量

css通过@supports性能查询语法来检测

语法:

@supports (--a: 0){.box{background-color:#c00;}
}
@supports(not(--a: 0)){.box{background-color:#cc0;}
}

js语法检测:

const isSupported = window.CSS && window.CSS.supports && window.CSS.supports('--a', 0);if (isSupported) {/* supported */
} else {/* not supported */
}

参考链接:

  1. 阮一峰老师:http://www.ruanyifeng.com/blog/2017/05/css-variables.html
  2. google developers: https://developers.google.com/web/updates/2016/02/css-variables-why-should-you-care
  3. MDN:https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties

http://chatgpt.dhexx.cn/article/XXa22OlY.shtml

相关文章

详解CSS(一)

&#x1f3cd;️作者简介&#xff1a;大家好&#xff0c;我是亦世凡华、渴望知识储备自己的一名在校大学生 &#x1f6f5;个人主页&#xff1a;亦世凡华、的博客 &#x1f6fa;系列专栏&#xff1a;CSS专栏 &#x1f6b2;给大家推荐一个网站&#x1f609;很实用&#x1f61a;我…

读书笔记《MySQL技术内幕:InnoDB存储引擎》第5章 索引与算法

索引是应用程序设计和开发的一个重要方面。若索引太多&#xff0c;应用程序的性能可能会受到影响。而索引太少&#xff0c;对查询性能又会产生影响。要找到一个合适的平衡点&#xff0c;这对应用程序的性能至关重要。 一些开发人员总是在事后才想起添加索引——我一直认为&…

32.项目总结--技术点部分

项目整体架构 Docker 虚拟化容器计数,Docker基于镜像,可以秒级启动各种容器,每一种容器都是一个完整的运行环境,容器之间相互隔离; 安装docker 安装前卸载原有的docker yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-lat…

【HCIA-Datacom V1.0培训教材】广域网技术

局域网LAN&#xff08;Local Area Network&#xff09; 广域网WAN&#xff08;Wide Area Network&#xff09; 数字数据网DDN&#xff08;Digital Data Network&#xff09; 帧中继FR(Frame Relay) 同步数字结构SDH&#xff08;Synchronous Digital Hierachy&#xff09; …

一文了解Docker容器技术的操作

一文了解Docker容器技术的操作 前言 相信点进这篇文章的Coder&#xff0c;不管是在各大技术论坛上、技术交流群&#xff0c;亦或招聘网上&#xff0c;应该都有见到过Doker容器技术的面孔&#xff0c;随着社会节奏的加快以及迫于生活的压力&#xff0c;在计算机技术日新月异的今…

自然语言处理简介(1)---- 服务梳理与传统汉语分词

文章大纲 1.Nlp技术体系简介1.1 基础技术1.2 Nlp 核心技术1.3 NlP&#xff08;高端技术&#xff09; 2.知名NLP 服务系统简介2.1汉语分词系统ICTCLAS2.2 哈工大语言云&#xff08;Language Technology Platform&#xff0c;LTP&#xff09;2.3 Amazon Comprehend2.4 阿里云NLP2…

微服务技术栈学习笔记(自用)

微服务技术栈学习笔记&#xff08;自用&#xff09; 文章目录 微服务技术栈学习笔记&#xff08;自用&#xff09;1.导学2.Eureka2.1微服务远程调用&#xff1a;2.2搭建Eureka 3.Ribbon负载均衡4.Nacos4.1服务注册4.2 分级存储 5.Feign6.Gateway6.1搭建6.2路由断言工厂6.3 过滤…

自然语言处理技术

自然语言处理技术&#xff08;NLP&#xff09;在推荐系统中的应用 NLP 推荐系统 词袋模型 阅读7798 作者&#xff1a; 张相於&#xff0c;58集团算法架构师&#xff0c;转转搜索推荐部负责人&#xff0c;负责搜索、推荐以及算法相关工作。多年来主要从事推荐系统以及机器学习…

Java.mob.org.cn搜索_探讨Android全文检索技术

原标题&#xff1a;探讨Android全文检索技术 写在前面 客户端本地存储数据一般使用的存储方式是&#xff1a;文件、SharedPreference、数据库(SQLite) 如果我们要做一些查询的操作&#xff0c;对于文件的方式&#xff0c;通过序列化和反序列化来进行数据的增删改查操作&#xf…

seg:NLP之正向最大匹配分词

已迁移到我新博客,阅读体验更佳seg:NLP之正向最大匹配分词 完整代码实现放在我的github上:click me 一、任务要求 实现一个基于词典与规则的汉语自动分词系统。 二、技术路线 采用正向最大匹配(FMM)方法对输入的中文语句进行分词&#xff0c;具体的实现可以分为下面几个步骤&am…

Elasticsearch搜索技术实战

elasticsearch下载安装 本篇前述的ES版本是7.14.2&#xff0c;实现了与Mysql的数据同步&#xff0c;ES端的搜索与分词&#xff1b;后来由于和Springcloud&#xff08;spring-data-elasticsearch:3.0.6&#xff09;集成发现版本问题&#xff0c;换成ES5.5.0&#xff0c;所以完整…

Docker技术

在这里插入代码片# Docker 官方文档地址:https://www.docker.com/get-started 中文参考手册:https://docker_practice.gitee.io/zh-cn/ 1.什么是 Docker 1.1 官方定义 最新官网首页 # 1.官方介绍 - We have a complete container solution for you - no matter who you are…

Elasticsearch - 文档分析,IK分词器;文档冲突(十二)

阅读本文前可先参考 Elasticsearch - Elasticsearch详解&#xff1b;安装部署&#xff08;一&#xff09;_MinggeQingchun的博客-CSDN博客 https://blog.csdn.net/MinggeQingchun/article/details/126855747 一、文档分析 文档分析过程如下&#xff1a; 1、将一块文本分成适…

springboot+Elasticsearch实现word,pdf,txt内容抽取并高亮分词全文检索

文章目录 需求 一、环境 二、功能实现 1.搭建环境 2.文件内容识别 三.代码 需求 产品希望我们这边能够实现用户上传PDF,WORD,TXT之内得文本内容&#xff0c;然后用户可以根据附件名称或文件内容模糊查询文件信息&#xff0c;并可以在线查看文件内容 一、环境 项目开发环境&…

使用lucce分词怎么_ElasticSearch 分词器,了解一下

这篇文章主要来介绍下什么是 Analysis &#xff0c;什么是分词器&#xff0c;以及 ElasticSearch 自带的分词器是怎么工作的&#xff0c;最后会介绍下中文分词是怎么做的。 首先来说下什么是 Analysis&#xff1a; 什么是 Analysis&#xff1f; 顾名思义&#xff0c;文本分析就…

自然语言处理 # 中文分词技术 概述

定义 中文分词&#xff08;Chinese Word Segmentation&#xff09;就是将连续的字序列按照一定的规范重新组合成词序列的过程。 Ques:为什么要分词&#xff1f; Ans: 词是最小的能够独立运用的语言单位 Ques:什么是独立运用呢&#xff1f; Ans:它可以解释为“单独做句法成分或…

Python 中 concurrent.futures 模块使用说明

Python 中 concurrent.futures 模块使用说明 转载请注明出处&#xff1a;https://blog.csdn.net/jpch89/article/details/87643972 文章目录 Python 中 concurrent.futures 模块使用说明0. 参考资料1. 概述2. Executor Object 执行器对象3. ThreadPoolExecutor 线程池执行器4.…

【ruoyi】java.util.concurrent.RejectedExecutionException: Task java.util.concurrent.ScheduledThreadPoo

前言 ruoyi 4.6.0jdk1.8 错误 11:48:16.879 [http-nio-9031-exec-25] INFO c.r.f.s.r.UserRealm - [doGetAuthenticationInfo,128] - 对用户[admin]进行登录验证..验证未通过{} java.util.concurrent.RejectedExecutionException: Task java.util.concurrent.ScheduledThre…

【学习积累】Queue 与 ConcurrentQueue性能测试

在 C# 中&#xff0c;关于队列&#xff08;Queue&#xff09;有两种&#xff0c;一种就是我们普通使用的队列&#xff0c;另一种是线程安全的队列 ConcurrentQueue<T> 。 ConcurrentQueue表示线程安全的先进先出 (FIFO) 集合。https://learn.microsoft.com/zh-cn/dotnet…

Python报错ModuleNotFoundError: No module named ‘concurrent‘

在测试Python的多线程时&#xff0c;根据官方的说法&#xff0c;concurrent.futures在Python3中已经内置了&#xff0c;不需要下载安装&#xff0c;如果是Python2则需要运行pip install futures进行安装。。。 这样导入&#xff0c;两种写法均可 import concurrent.futures #…