如何用JavaScript动态修改CSS样式表

 我来答
TGS0016
2013-08-24 · 超过53用户采纳过TA的回答
知道答主
回答量:107
采纳率:100%
帮助的人:103万
展开全部
  正好今天在论坛碰到一位朋友问这样的一个问题:<style </script   有的朋友回答:如果使用.ls的对象很多的话,用JS确实不方便, jquery方便,$(.ls).width(200);这样就行。   他是想用JQ的类选择器.ls选择所有使用这个样式的对象,对它们逐个进行调整,而非更改CSS样式表,所以会有对象很多的顾虑。   但问题是,这只是改了那些对象的具体表现样式,而并非改了.LS的设置。如果再出现一个使用.LS风格的元素,它还是老样子,你还需要对这个元素再去调整,治标不治本。而且这种方式也决定了不可能简单地通过一句话就实现。   这样想的人还不少,而如果你看了《如何用JavaScript动态建立或增加CSS样式表》这篇文章之后,相信你很容易就想到如何用一句话来解决这个问题,既简洁高效(浏览器会自动重新设置所有应用这个样式的元素),而且真正的修改了样式设置,新增的使用这个样式的元素将自动应用被修改过的设置。于是,你已经学到了和很多人区分开来的更高阶的知识。下面我把方法具体再说一下:   由于上面的例子,不容易看出效果,我下面另外写了个例子,通过颜色的改变,比较容易看到效果:view plain<STYLE .theforever {width:50px;color:red;} #theforever {width:150px;color:silver;}</STYLE<div class=theforever这里应该是红色的,但它会被下面的JS通过改变CSS样式设置而变成黄色</div <div id=theforever这里应该是银灰色的,的确这个不会发生变化,只作为对比</div<scriptdocument.styleSheets[0].cssText=document.styleSheets[0].cssText.replace(/red/g,yellow); </script   上面的例子,针对的不是某个特定的样式名称,而是泛泛的颜色(如果你直接挪到含有更为复杂的CSS页面里,其中有不表示颜色的RED字样,这还会导致错误。我对不动脑子的代码拿来主义者一向极其反感,不作过多指示),但如果想要针对特定的样式名称进行更改,同样很容易:   从上面,可以看出document.styleSheets[0].cssText就是整个<STYLE</STYLE内部的内容,相当于一个字串变量,所以假如针对.LS要改变它的设置,只需要把.ls{width=120px;}作为 replace 要替换的部分,把.ls{width=555px;}作为替换目标,这样就行了。
百度网友834a0a1e3
2015-08-24 · TA获得超过835个赞
知道小有建树答主
回答量:1031
采纳率:62%
帮助的人:163万
展开全部
document.getElementById("myid").style.display = "block";

一般都是上面这种格式, 也可以:

element = document.querySelector('selectors');
element.style.display = "none";
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
君丶恍然如梦
2015-08-02 · 超过41用户采纳过TA的回答
知道小有建树答主
回答量:189
采纳率:0%
帮助的人:46万
展开全部
针对与某一个控件进行样式修改吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
静的姿态
2015-08-12 · 超过61用户采纳过TA的回答
知道小有建树答主
回答量:142
采纳率:0%
帮助的人:84万
展开全部
使用 jquery .css()
搜索 jquery css 查看官方文档说明, 里面有例子
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式