如何使用 JavaScript 动态修改 CSS 变量的值?

简介: 【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。

通过 document.documentElement.style.setProperty() 方法

  • 原理document.documentElement 指向文档的根元素(通常是 <html> 元素),setProperty() 方法用于设置CSS属性值。通过该方法,可以直接修改CSS变量的值,从而改变应用了该变量的元素的样式。
  • 示例:假设在CSS中定义了一个名为 --main-color 的变量,初始值为蓝色,想要通过JavaScript将其修改为红色,可以这样写:
:root {
   
  --main-color: blue;
}

body {
   
  background-color: var(--main-color);
}
// 获取文档根元素
var root = document.documentElement;
// 修改CSS变量的值
root.style.setProperty('--main-color', 'red');

在上述代码中,通过 setProperty() 方法将 --main-color 的值修改为红色,页面的背景颜色也会随之变为红色,因为 body 元素的背景颜色应用了该变量。

使用 getComputedStyle() 方法获取当前变量值并修改

  • 原理getComputedStyle() 方法可以获取元素的最终计算样式,包括应用了CSS变量后的实际样式值。通过该方法获取到当前CSS变量的值后,可以根据需要进行修改,并再次使用 setProperty() 方法设置新的值。
  • 示例:以下代码演示了如何获取当前 --main-color 变量的值,并在其基础上进行修改:
// 获取文档根元素
var root = document.documentElement;
// 获取当前 --main-color 变量的计算值
var currentColor = getComputedStyle(root).getPropertyValue('--main-color');
// 对获取到的值进行处理,例如将其颜色变深
var newColor = darkenColor(currentColor);
// 修改CSS变量的值
root.style.setProperty('--main-color', newColor);

function darkenColor(color) {
   
  // 这里简单地将颜色的RGB值中的每个分量减50来变深颜色,实际应用中可根据具体需求更精确地处理
  var r = Math.max(0, parseInt(color.slice(1, 3), 16) - 50).toString(16).padStart(2, '0');
  var g = Math.max(0, parseInt(color.slice(3, 5), 16) - 50).toString(16).padStart(2, '0');
  var b = Math.max(0, parseInt(color.slice(5, 7), 16) - 50).toString(16).padStart(2, '0');
  return '#' + r + g + b;
}

在上述示例中,首先获取了当前 --main-color 变量的计算值,然后通过一个自定义函数 darkenColor() 将颜色变深,最后将新的颜色值设置回 --main-color 变量,实现了动态修改CSS变量并改变页面样式的效果。

通过类名切换修改CSS变量

  • 原理:可以事先定义多个类,每个类中设置不同的CSS变量值,然后通过JavaScript动态地切换元素的类名,从而间接修改CSS变量的值。这种方法在一些复杂的样式切换场景中比较有用,可以将不同的样式组合定义在不同的类中,方便管理和维护。
  • 示例
.theme-light {
   
  --text-color: black;
  --background-color: white;
}

.theme-dark {
   
  --text-color: white;
  --background-color: black;
}
<button onclick="toggleTheme()">切换主题</button>
<p class="theme-light">这是一段文字</p>
function toggleTheme() {
   
  var element = document.querySelector('p');
  element.classList.toggle('theme-dark');
  element.classList.toggle('theme-light');
}

在上述代码中,定义了两个类 theme-lighttheme-dark,分别设置了不同的 --text-color--background-color 变量值。当点击按钮时,通过JavaScript切换 p 元素的类名,从而实现了主题的切换,即改变了CSS变量的值和相应的页面样式。

使用 CSSStyleDeclaration 对象的 setProperty() 方法

  • 原理:除了通过文档根元素的 style 属性来设置CSS变量,还可以获取元素的 style 属性所对应的 CSSStyleDeclaration 对象,然后使用该对象的 setProperty() 方法来设置CSS变量的值。这种方法可以针对特定的元素来修改其应用的CSS变量,而不影响其他元素。
  • 示例
<p id="myPara" style="color: var(--text-color);">这是一段文字</p>
<button onclick="changeTextColor()">改变文字颜色</button>
function changeTextColor() {
   
  var para = document.getElementById('myPara');
  var style = para.style;
  style.setProperty('--text-color', 'green');
}

在上述示例中,点击按钮时,通过获取 p 元素的 style 属性对象,并使用其 setProperty() 方法将 --text-color 变量的值修改为绿色,从而改变了该段落文字的颜色。

使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。

相关文章
|
5月前
|
移动开发 前端开发 JavaScript
征信报告修改器,征信报告生成器,制作软件无痕修改软件【js+html+css】
本项目为信用评分模拟器教学工具,采用HTML5实现,仅供学习参考。核心功能通过JavaScript构建,包含虚拟数据生成、权重分配及信用因素分析(如还款记录、信用使用率等)。
|
5月前
|
存储 自然语言处理 前端开发
抖音快手小红书虚拟评论截图生成器,模拟对话制作工具,html+js+css
这是一款纯前端实现的多平台虚拟评论生成器,支持抖音、快手、小红书风格,适用于产品演示与UI设计。采用Vanilla JS与Flexbox布局,利用IndexedDB存储数据,CSS Variables切换主题。
|
5月前
|
前端开发 JavaScript
个人征信电子版无痕修改, 个人信用报告pdf修改,js+html+css即可实现【仅供学习用途】
本代码展示了一个信用知识学习系统的前端实现,包含评分计算、因素分析和建议生成功能。所有数据均为模拟生成
|
5月前
|
存储 前端开发 安全
病历单生成器在线制作,病历单生成器app,HTML+CSS+JS恶搞工具
本项目为医疗病历模拟生成器,旨在为医学教学和软件开发测试提供数据支持,严格遵守《医疗机构病历管理规定》。
|
5月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
5月前
|
前端开发 容器
处方单图片生成器, 处方单在线制作免费,js+css+html恶搞神器
这是一个电子处方模拟生成系统,使用html2canvas库实现图片导出功能。系统生成的处方单包含多重防伪标识,并明确标注为模拟数据,仅供学习
|
5月前
|
前端开发
个人征信PDF无痕修改软件,个人征信模板可编辑,个人征信报告p图神器【js+html+css仅供学习用途】
这是一款信用知识学习系统,旨在帮助用户了解征信基本概念、信用评分计算原理及信用行为影响。系统通过模拟数据生成信用报告,涵盖还款记录
|
5月前
|
前端开发 JavaScript 容器
制作b超单生成器, 假怀孕b超单图片制作, p图医院证明【css+html+js装逼恶搞神器】
本资源提供一个适合用于熟人之间恶搞的工具,效果逼真,仅供学习参考与娱乐。包含前端技术学习要点:语义化布局、响应式设计、Flexbox、图片自适应
|
5月前
|
前端开发
医院检查单子p图软件,在线制作仿真病历,js+css+html装逼神器
本示例展示如何用HTML/CSS创建医疗信息页面,内容仅供学习参考。页面模拟“阳光医院体检中心”场景,提供预约功能验证(如姓名、手机号、日期)。所有数据仅用于演示

热门文章

最新文章

  • 1
    React 中如何安装与使用 Tailwind CSS
    195
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    82
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    123
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    108
  • 5
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    75
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    199
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    206
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    105
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    59
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    99