0

0

CSS与JavaScript的通信引入_CSS变量在JS中的应用

P粉602998670

P粉602998670

发布时间:2026-02-19 08:45:36

|

565人浏览过

|

来源于php中文网

原创

最稳定方式是用getcomputedstyle().getpropertyvalue()读取css自定义属性;修改则通过element.style.setproperty()设置,注意作用域、拼写和执行时机,避免强制同步布局。

css与javascript的通信引入_css变量在js中的应用

怎么在 JavaScript 里读取 CSS 自定义属性(--xxx

直接用 getComputedStyle + getPropertyValue,这是最稳定、兼容性最好的方式。别试图去解析 style 属性或遍历 cssRules,那些要么拿不到全局变量,要么跨 shadow DOM 失效。

常见错误现象:element.style.getPropertyValue('--color') 返回空字符串——因为 style 只读内联样式,不包含来自 :root 或选择器的变量。

  • 先获取计算后样式:const styles = getComputedStyle(document.documentElement)(读 :root)或 getComputedStyle(el)(读元素最终生效值)
  • 再取值:styles.getPropertyValue('--primary-color'),注意带两个短横线和引号
  • 返回值总是字符串,哪怕你设的是数字,比如 '24' 而不是 24,需要手动 parseIntparseFloat

怎么在 JavaScript 里动态修改 CSS 变量

:root 或任意元素的 style 属性即可,本质是写内联样式,优先级高于外部 CSS 中的同名变量。

使用场景:主题切换、尺寸响应式调整、动画中间态控制。不要用 JS 去重写整个 CSS 文件或操作 document.styleSheets,维护成本高且容易出竞态。

立即学习Java免费学习笔记(深入)”;

商务通(在线客服系统)
商务通(在线客服系统)

一款无需安装的即时交流系统,只需申请一个帐号,将一段代码嵌入贵站网页中,就可以让客服人员发现所有到达您网站的访客,而且可以看到访客的来源、使用的搜索引擎等,您可以主动发起对话与访客沟通,进行产品推销,从而大大提高产品销售成功率。 还是一款协同管理软件,在保持与客户信息通畅的同时,也保持公司内部之间的信息交流,从而提高企业的工作效率和客户服务质量。 管理员帐号:biiz.cn 密码:biiz.cn

下载
  • 改全局变量:document.documentElement.style.setProperty('--bg', '#ffeb3b')
  • 改某元素变量:myEl.style.setProperty('--hover-scale', '1.2')
  • 删变量:myEl.style.removeProperty('--hover-scale'),会回退到上级定义(如 :root)或初始值
  • 批量设置建议用 Object.assign(el.style, { '--a': '1', '--b': '2' }),但注意这会覆盖其他内联样式,慎用

getPropertyValue 拿不到值?检查这三件事

不是 JS 写错了,大概率是 CSS 变量根本没生效,或者作用域不对。

常见错误现象:控制台打印 '''null',但开发者工具里明明看到变量存在。

  • 确认变量已声明且拼写完全一致(区分大小写,--MainColor--main-color
  • 确认作用域:如果从 :root 读,但变量只在 .card 里定义,那 getComputedStyle(document.documentElement) 就读不到
  • 确认时机:脚本执行时 DOM 是否就绪?变量是否被后续 CSS 覆盖?建议在 DOMContentLoaded 后读,或用 MutationObserver 监听 style 变化(极少需要)

CSS 变量传给 JS 的性能和边界要注意什么

读写本身极快,但频繁读取(比如在 requestAnimationFrame 里)可能触发强制同步布局(forced layout),尤其当依赖的变量影响几何属性时。

性能影响比想象中敏感:一次 getComputedStyle 调用可能让浏览器重排,连续读多个属性更糟。

  • 读取尽量合并:用一个 getComputedStyle 结果,多次 getPropertyValue,别反复调用
  • 避免在 scroll / resize 回调里直接读变量,缓存值或节流
  • JS 无法监听 CSS 变量变化,想响应式更新得自己封装逻辑(比如配合 CustomEventProxy 包裹 setProperty)
  • IE 完全不支持 CSS 变量,如果还要兼容,得 fallback 到 data-attribute 或 class 切换

真正复杂的地方不在语法,而在变量生命周期管理——谁定义、谁读、谁改、改完谁响应。这些关系一旦松散,调试时就会发现值“好像变了又没变”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

786

2024.03.01

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

547

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

85

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

101

2025.09.18

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

573

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1553

2023.10.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

CSS教程
CSS教程

共754课时 | 33.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号