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


Posted in Javascript onMay 20, 2016

看过我写的《用JavaScript动态建立或增加CSS样式表的实现方法》之后,你就很容易想明白如何修改CSS样式表了。

正好今天在论坛碰到一位朋友问这样的一个问题:

<style>
.ls{width=120px;}
</style>
<script>
//在这里加一句来改变.ls中width的值,如何写
</script>

有的朋友回答:“如果使用.ls的对象很多的话,用JS确实不方便, jquery方便,$(".ls").width(200);这样就行”。

他是想用JQ的类选择器.ls选择所有使用这个样式的对象,对它们逐个进行调整,而非更改CSS样式表,所以会有“对象很多”的顾虑。

但问题是,这只是改了那些对象的具体表现样式,而并非改了.LS的设置。如果再出现一个使用.LS风格的元素,它还是老样子,你还需要对这个元素再去调整,治标不治本。而且这种方式也决定了不可能简单地通过一句话就实现。

这样想的人还不少,而如果你看了《用JavaScript动态建立或增加CSS样式表的实现方法》这篇文章之后,相信你很容易就想到如何用一句话来解决这个问题,既简洁高效(浏览器会自动重新设置所有应用这个样式的元素),而且真正的修改了样式设置,新增的使用这个样式的元素将自动应用被修改过的设置。于是,你已经学到了和很多人区分开来的更高阶的知识。下面我把方法具体再说一下:

由于上面的例子,不容易看出效果,我下面另外写了个例子,通过颜色的改变,比较容易看到效果:

<STYLE>
	.theforever {width:50px;color:red;}
	#theforever {width:150px;color:silver;}
</STYLE>
<div class="theforever">这里应该是红色的,但它会被下面的JS通过改变CSS样式设置而变成黄色</div>
<div id="theforever">这里应该是银灰色的,的确这个不会发生变化,只作为对比</div>
<script>
document.styleSheets[0].cssText=document.styleSheets[0].cssText.replace(/red/g,"yellow");
//一句,不就OK了?
</script>

上面的例子,针对的不是某个特定的样式名称,而是泛泛的颜色(如果你直接挪到含有更为复杂的CSS页面里,其中有不表示颜色的RED字样,这还会导致错误。我对不动脑子的代码拿来主义者一向极其反感,不作过多指示),但如果想要针对特定的样式名称进行更改,同样很容易:

从上面,可以看出document.styleSheets[0].cssText就是整个<STYLE></STYLE>内部的内容,相当于一个字串变量,所以假如针对.LS要改变它的设置,只需要把“.ls{width=120px;}”作为 replace 要替换的部分,把“.ls{width=555px;}”作为替换目标,这样就行了。

以上这篇如何用JavaScript实现动态修改CSS样式表就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
你所要知道JS(DHTML)中的一些技巧
Jan 09 Javascript
Node.js异步I/O学习笔记
Nov 04 Javascript
js继承实现方法详解
Dec 16 Javascript
jQuery如何跳转到另一个网页 就这么简单
Dec 28 Javascript
从零开始学习Node.js系列教程四:多页面实现数学运算的client端和server端示例
Apr 13 Javascript
基于Vue的文字跑马灯组件(npm 组件包)
May 24 Javascript
微信小程序 http请求的session管理
Jun 07 Javascript
JS获取填报扩展单元格控件的值的解决办法
Jul 14 Javascript
修改vue+webpack run build的路径方法
Sep 01 Javascript
JavaScript实现京东放大镜效果
Dec 03 Javascript
微信小程序实现加入购物车滑动轨迹
Nov 18 Javascript
VUE项目实现主题切换的多种方法
Nov 26 Vue.js
JavaScript中的跨浏览器事件操作的基本方法整理
May 20 #Javascript
用JavaScript动态建立或增加CSS样式表的实现方法
May 20 #Javascript
详解JavaScript中的事件流和事件处理程序
May 20 #Javascript
jQuery基础的工厂函数以及定时器的经典实例分析
May 20 #Javascript
JavaScript中的Object对象学习教程
May 20 #Javascript
jQuery基本选择器(实例及表单域value的获取方法)
May 20 #Javascript
jQuery的实例及必知重要的jQuery选择器详解
May 20 #Javascript
You might like
php ftp文件上传函数(基础版)
2010/06/03 PHP
php与mysql建立连接并执行SQL语句的代码
2011/07/04 PHP
php 中英文语言转换类
2011/09/07 PHP
php绘制圆形的方法
2015/01/24 PHP
ThinkPHP安装和设置
2015/07/27 PHP
PHP载入图像imagecreatefrom_gif_jpeg_png系列函数用法分析
2016/11/14 PHP
PHP判断是手机端还是PC端 PHP判断是否是微信浏览器
2017/03/15 PHP
php实现对文件压缩简单的方法
2019/09/29 PHP
jquery 多行滚动代码(附详细解释)
2010/06/17 Javascript
将input file的选择的文件清空的两种解决方案
2013/10/21 Javascript
jQuery判断元素是否存在的可靠方法
2014/05/06 Javascript
jQuery往textarea中光标所在位置插入文本的方法
2015/06/26 Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
2017/08/19 Javascript
js实现上传并压缩图片效果
2018/01/10 Javascript
详解js删除数组中的指定元素
2018/10/31 Javascript
微信小程序局部刷新触发整页刷新效果的实现代码
2018/11/21 Javascript
JS选取DOM元素常见操作方法实例分析
2018/12/10 Javascript
微信小程序整个页面的自动适应布局的实现
2020/07/12 Javascript
JavaScript对象访问器Getter及Setter原理解析
2020/12/08 Javascript
[54:53]2014 DOTA2国际邀请赛中国区预选赛 LGD-GAMING VS CIS 第二场
2014/05/23 DOTA
python类继承与子类实例初始化用法分析
2015/04/17 Python
python中星号变量的几种特殊用法
2016/09/07 Python
Python subprocess模块详细解读
2018/01/29 Python
基于Python函数和变量名解析
2019/07/19 Python
Tensorflow tf.dynamic_partition矩阵拆分示例(Python3)
2020/02/07 Python
HTML5 canvas基本绘图之图形组合
2016/06/27 HTML / CSS
海淘零差价,宝贝全球购: 宝贝格子
2016/08/24 全球购物
阿玛尼化妆品美国官网:Giorgio Armani Beauty
2017/02/02 全球购物
通信工程毕业生自荐信
2013/11/01 职场文书
村长贪污检举信
2014/04/04 职场文书
幼儿园安全责任书范本
2014/07/24 职场文书
商场圣诞节活动总结
2015/05/06 职场文书
请病假条范文
2015/08/17 职场文书
2016年校园社会综合治理宣传月活动总结
2016/03/16 职场文书
婚礼必备主持词范本!
2019/07/23 职场文书
简单了解 MySQL 中相关的锁
2021/05/25 MySQL