当前位置:首页 > 编程技术 > 正文内容

JS动态操控CSS样式:赋予网页无限生机

yc8887个月前 (04-10)编程技术136

1. 获取和设置样式

1.1 获取CSS样式

 JS动态操控CSS样式:赋予网页无限生机

我们可以使用window.getComputedStyle()方法获取元素的所有计算样式(包括浏览器默认样式、外部样式表、内联样式以及CSSOM修改过的样式):

let element = document.getElementById('myElement'); let style = window.getComputedStyle(element); console.log(style.getPropertyValue('color')); // 获取颜色值

1.2 设置CSS样式

直接操作DOM元素的style属性可以设置内联样式:

element.style.color = 'red'; // 设置颜色为红色 element.style.backgroundColor = 'blue'; // 设置背景色为蓝色


对于非行内样式或者需要添加多个样式时,可以创建并应用新的CSSRule:

let sheet = document.styleSheets[0]; // 获取样式表 let rule = `#myElement { color: green; }`; sheet.insertRule(rule, sheet.cssRules.length); // 插入新规则

2. 动态切换CSS类

通过JavaScript切换CSS类名是一种更方便且结构清晰的方式来动态改变样式:

element.classList.add('active'); // 添加类 element.classList.remove('inactive'); // 移除类 element.classList.toggle('visible'); // 切换类

配合CSS预设好的类,可以实现复杂的动画效果或状态变化。

3. 使用CSS Variables(CSS自定义属性)

CSS变量让JavaScript对CSS样式的控制更为强大和灵活:

element.style.setProperty('--main-color', 'purple'); // 设置CSS变量

然后在CSS中引用这个变量:

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

这样一来,只需更改JavaScript中的变量值,整个页面的相关样式都会随之改变。

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/11195.html

分享给朋友:

“ JS动态操控CSS样式:赋予网页无限生机” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】vagrant实现linux虚拟机的安装并配置网络

【说站】vagrant实现linux虚拟机的安装并配置网络

一、VirtualBox的下载和安装1、下载VirtualBox官网下载:https://www.virtualbox.org/wiki/Downloads我的电脑是Windows的,所以下载Wind...

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...

【说站】linux中redis如何以redis用户重启?

【说站】linux中redis如何以redis用户重启?

通过上图我们可以看到,目前状态是已经以 redis 用户启动着,我想修改下 redis 的密码,然后怎么以 redis 用户重启呢?redis 是 nologin 用户,不能通过 su redis 切...