document 改变css,如何在运行时更改/删除CSS类定义?

我在http://twelvestone.com/forum_thread/view/31411找到了一个答案,我在这里逐字复制了线程的某些部分,因为我担心该线程以及非常有用的答案会消失。

Flip 2006.06.26,02:45 PM — [Crunchy Frog]帖子:2470加入日期:2003.01.26

在经过大约10到12个小时的搜索,阅读和修补之后,我已经做到了!我今天是CSS / JS代码忍者!

使用的JS代码如下:

function changeRule(theNumber) {

var theRules = new Array();

if (document.styleSheets[0].cssRules) {

theRules = document.styleSheets[0].cssRules;

} else if (document.styleSheets[0].rules) {

theRules = document.styleSheets[0].rules;

}

theRules[theNumber].style.backgroundColor = '#FF0000';

}

我已经在FF(Mac),Safari(Mac),O9(Mac),IE5(Mac),IE6(PC),FF(PC)上进行了测试,它们都可以工作。之所以使用'if'语句,是因为某些浏览器使用cssRules ...有些仅使用规则...而唯一的缺点是您不能使用“ background-color”来指代样式,删除连字符并大写连字符后的第一个字母。

要引用第一个CSS规则,请使用“ changeRule(0)”,第二个“ changeRule(1)”和第三个“ changeRule(2)”,依此类推...

我还没有找到无法在其上运行的浏览器。。。。。。。。。。。。。。。。。一遍一遍又一遍。

BillyBones 2011.01.20,11:57 AM — [在桶中]帖子:1加入日期:2011.01.20

您好,我在这些论坛中注册只是为了添加这一点,因为我无法在其他地方方便地找到它:

function changeStyle(selectorText)

{

var theRules = new Array();

if (document.styleSheets[0].cssRules) {

theRules = document.styleSheets[0].cssRules;

}

else if (document.styleSheets[0].rules) {

theRules = document.styleSheets[0].rules;

}

for (n in theRules)

{

if (theRules[n].selectorText == selectorText)   {

theRules[n].style.color = 'blue';

}

}

}

这只是使CSS规则可以通过选择器名称而不是cssRules数组中的索引号来识别。

换句话说,您可以使用字符串参数“ selectorText”来执行Javascript函数,而不是难以记住的数字(如果添加了新样式,则该数字容易频繁更改)。

谢谢您为Flip进行的10到12个小时的研究,希望我能做一个有价值的补充。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用JavaScript来动态修改CSS的样式。 首先,用document.querySelector()或document.getElementById()等方法获取要修改样式的元素。 然后,使用element.style.property = value来修改样式属性的值,其中element是获取到的元素,property是要修改的样式属性,value是该属性的新值。例如,要修改元素的背景色为红色,可以这样写: ```javascript var element = document.querySelector('.my-element'); element.style.backgroundColor = 'red'; ``` 另外,也可以使用element.setAttribute('style', 'property: value;')来修改元素的style属性,其中property和value的含义同上。例如: ```javascript var element = document.getElementById('my-element'); element.setAttribute('style', 'background-color: red;'); ``` ### 回答2: 动态修改CSS样式有多种方式。一种常用的方式是使用JavaScript来修改元素的样式。通过JavaScript可以通过获取元素的引用,然后使用该引用来修改元素的样式。可以使用元素的style属性来直接修改元素的内联样式,也可以使用classList属性来修改元素的类名。通过修改类名,可以通过预先定义好的CSS样式来改变元素的样式。 举例来说,假设我们有一个id为"myElement"的元素,它的颜色是蓝色,现在我们想将它的颜色改为红色。我们可以使用以下JavaScript代码来实现: ```javascript var element = document.getElementById("myElement"); element.style.color = "red"; ``` 以上代码通过getElementById方法获取到id为"myElement"的元素,并将其引用赋值给变量element。然后,通过设置元素的style.color属性为"red",将元素的颜色修改为红色。 另一种方式是使用classList属性来添加、移除或切换元素的类名。我们可以先在CSS定义一个名为"red-color"的类,该类的样式是将颜色设置为红色。然后,通过JavaScript可以将该类名添加到或从元素的classList中来改变元素的样式。 ```javascript var element = document.getElementById("myElement"); element.classList.add("red-color"); ``` 以上代码使用classList.add方法将名为"red-color"的类名添加到元素的classList中,从而改变元素的样式为红色。 总结起来,动态修改CSS样式可以通过JavaScript来实现,通过直接修改元素的style属性或通过classList来修改元素的类名来改变元素的样式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值