值得一看
广告
彩虹云商城
广告

热门广告位

如何利用 JavaScript 的 CSSOM 动态操作样式表规则?

通过CSSOM可动态操作样式表,如增删改规则;利用document.styleSheets获取样式表集合,遍历cssRules读取规则,用insertRule和deleteRule插入删除规则,动态创建style标签可避免影响现有样式,适用于主题切换与样式管理。

如何利用 javascript 的 cssom 动态操作样式表规则?

JavaScript 的 CSSOM(CSS Object Model)提供了直接操作样式表的能力,不只是修改单个元素的 style 属性,还能动态增删改整个 CSS 规则。这在实现主题切换、运行时样式注入或组件化样式管理时非常有用。

访问样式表

通过 document.styleSheets 可以获取页面中所有样式表的集合,包括 link 引入的和 style 标签内联的:

const sheets = document.styleSheets;

每个 sheet 对象代表一个 CSSStyleSheet 实例,可通过索引访问:

const sheet = document.styleSheets[0];

注意:跨域的外部样式表受同源策略限制,无法操作其 rules。

读取与修改 CSS 规则

CSSStyleSheet 的 cssRules 属性返回一个包含所有 CSSRule 的类数组对象。可以遍历规则进行查找或修改:

for (let rule of sheet.cssRules) {<br>  console.log(rule.selectorText, rule.style.cssText);<br>}

例如,想修改 .highlight 的背景色:

for (let rule of sheet.cssRules) {<br>  if (rule.selectorText === '.highlight') {<br>    rule.style.backgroundColor = 'yellow';<br>  }<br>}

插入新样式规则

使用 insertRule() 方法可在指定位置插入一条新规则:

sheet.insertRule('p { color: blue; }', 0);

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

酷表ChatExcel

酷表ChatExcel

北大团队开发的通过聊天来操作Excel表格的AI工具

酷表ChatExcel48

查看详情
酷表ChatExcel

第二个参数是插入位置索引,0 表示最前面。
实际应用中常用于动态创建类:

sheet.insertRule('.fade { opacity: 0.5; transition: opacity 0.3s; }', sheet.cssRules.length);

删除样式规则

通过 deleteRule(index) 删除指定位置的规则:

sheet.deleteRule(1); // 删除第二条规则

如果知道规则内容但不确定位置,可先遍历匹配再删除:

[...sheet.cssRules].forEach((rule, index) => {<br>  if (rule.selectorText === '.obsolete') {<br>    sheet.deleteRule(index);<br>  }<br>});

创建新的样式表

若没有现成的可操作样式表,可动态创建并添加到页面:

const style = document.createElement('style');<br>document.head.appendChild(style);<br>const sheet = style.sheet;<br>sheet.insertRule('body { margin: 0; }', 0);

这种方式完全可控,避免影响已有样式表。

基本上就这些。掌握 CSSOM 操作后,你可以更灵活地管理样式逻辑,尤其适合封装成工具函数或 UI 主题系统。关键是理解 cssRules 的只读性(需用方法修改)和同源限制。不复杂但容易忽略细节。

相关标签:

css javascript java app 工具 跨域 JavaScript css Object if for foreach 封装 const Length console 对象 样式表 margin transition ui
温馨提示: 本文最后更新于2025-10-04 10:39:21,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞13赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容