全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JS如何设置元素样式的方法示例

一看到这个标题,大家可能首先想到的就是使用“[元素].style.[CSS属性名] = [属性值]”这样的套路去设置元素样式,但实际上,我们其实还有其他方式可以选择。

接下来,我将详细介绍三种设置元素样式的方式。

一、style

这个其实就是我们所熟知的方式,举个例子~~

<div id="box"></div>
var box = document.getElementById("box");
box.style.width = '100px';
box.style.height = '100px';
box.style.backgroundColor = "#f00";

显示效果:

这种方式看似简单粗暴,但写法过于繁冗,尤其是在需要添加很多样式时尤为突出。并且需要注意的是,对于使用短划线的CSS属性名,必须将其转换成驼峰大小写形式。(如示例中的backgroundColor)

二、style.cssText

这种方式相对于上面方法更为简洁,更像是直接在元素上写CSS:

[元素].style.cssText = [CSS样式];

例如:

box.style.cssText = 'width: 200px; height: 200px; border: 1px solid #f00;';

确实,写法上很方便。

但是,缺点是后面同样通过这种方式添加的样式会覆盖之前通过style特性指定的样式。

同样还是上面的例子,只不过是将两段JS写在一块:

var box = document.getElementById("box");
box.style.width = '100px';
box.style.height = '100px';
box.style.backgroundColor = "#f00";
box.style.cssText = 'width: 200px; height: 200px; border: 1px solid #f00;';

如果按照层叠样式表的特性,上面定义的红色的背景颜色应该还存在,然而实际上,下面通过style.cssText方式定义的样式会将style(包括style.cssText)方式添加的样式全部重写。所以,这个例子最终表现结果与上面只有一句时的效果是一样的:

最后注意下兼容性,IE8及更早版本均不支持cssText。

三、insertRule()

这个用法相对上面两种方法都较为复杂一些:

[sheet].insertRule([CSS样式],指定位置)

[sheet]表示某个样式表,它可以通过document.styleSheets来获得。那么,document.styleSheets又是什么呢? 说得简单一点就是应用在文档中的所有样式表,包括通过link标签引入的样式和style标签定义的样式。如果理解上还是有点困难,那么我们还是放个实例吧~~

首先头部引入样式表:

<link rel="stylesheet" type="text/css" href="css/index.css" rel="external nofollow" />

当然,这个样式表得真实存在,就算里面什么样式都不写也没关系。也可以直接用style标签,内容为空也不要紧。

然后用JS获取这个样式表:

var sheet = document.styleSheets[0];

最后我们就可以给这个样式表中添加样式了:

sheet.insertRule('#box{width: 300px; height: 300px; background-color: #0f0;}',0);

如果是在上面所有例子的基础上添加的这段代码,那么显示结果会是这样的:

大小还是200*200大小,背景颜色是绿色,说明通过style.cssText所设置的宽高样式把通过insertRule()设置的样式覆盖了,原因很简单,style(包括style.cssText)方式设置的样式属于行内样式,自然要比通过insertRule()设置的样式优先级更高咯~~

那么,示例当中insertRule()的第二个参数0又是指的什么呢?

它指的是我们需要添加CSS代码的位置,所以参数0就代表的是该样式表的最开始位置。

例如,我们先给样式表中手动添加一段样式(以下例子与上述例子无关):

<style>
  #box{ width: 100px; height: 100px;}
</style>
var sheet = document.styleSheets[0];
sheet.insertRule('#box{width: 300px; height: 300px; background-color: #0f0;}',0);

以上执行结果就是,宽高100*100的绿色盒子:

如果将insertRule()中的第二个参数改为1,那么通过JS添加的这段CSS代码相当于添加到了#box{ width: 100px; height: 100px;}的后面,类似下面这样:

<style>
  #box{ width: 100px; height: 100px;}
  #box{ width: 300px; height: 300px; background-color: #0f0;}
</style>

显示结果:

同样需要注意的是,insertRule()不兼容IE8及更早版本,但可以使用addRule()替代,语法稍微有点不同,上面例子这样写:

复制代码 代码如下:
sheet.addRule('#box','width: 300px; height: 300px; background-color: #0f0;',0);

第一个参数代表元素,第二个参数代表CSS样式,第三个参数代表插入位置,前两个参数必选,最后一个可选,不填则默认为0。

结束语:浏览器兼容性问题对于前端开发者来说一直是个很头疼的问题,很多问题也是主要集中在IE上,只希望可恶的IE早日退出历史舞台吧!希望对大家的学习有所帮助,也希望大家多多支持。


# js设置元素样式  # js设置元素class  # javaScript 读取和设置文档元素的样式属性  # js正确获取元素样式详解  # javascript获取元素CSS样式代码示例  # 原生js获取元素样式的简单方法  # 教你如何通过JavaScript读取元素的样式  # 样式表  # 的是  # 第二个  # 是在  # 又是  # 这段  # 什么呢  # 需要注意  # 更早  # 也不  # 第一个  # 是有  # 一句  # 也没  # 是这样  # 基础上  # 两种  # 将其  # 更高  # 很简单 


相关文章: PHP正则匹配日期和时间(时间戳转换)的实例代码  浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  广东企业建站网站优化与SEO营销核心策略指南  如何获取免费开源的自助建站系统源码?  浅析上传头像示例及其注意事项  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  制作农业网站的软件,比较好的农业网站推荐一下?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?  宝塔新建站点为何无法访问?如何排查?  建站之星展会模板:智能建站与自助搭建高效解决方案  实惠建站价格推荐:2025年高性价比自助建站套餐解析  建站与域名管理如何高效结合?  阿里云网站制作公司,阿里云快速搭建网站好用吗?  建站主机如何选?性能与价格怎样平衡?  C#如何序列化对象为XML XmlSerializer用法  Thinkphp 中 distinct 的用法解析  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  html制作网站的步骤有哪些,iapp如何添加网页?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  建站之星安装后如何自定义网站颜色与字体?  如何快速使用云服务器搭建个人网站?  七夕网站制作视频,七夕大促活动怎么报名?  建站之星如何快速生成多端适配网站?  C#如何使用XPathNavigator高效查询XML  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  代刷网站制作软件,别人代刷火车票靠谱吗?  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  如何在Windows 2008云服务器安全搭建网站?  建站之星如何实现PC+手机+微信网站五合一建站?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  建站之星北京办公室:智能建站系统与小程序生成方案解析  建站主机解析:虚拟主机配置与服务器选择指南  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  如何快速搭建高效可靠的建站解决方案?  如何零成本快速生成个人自助网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  深圳网站制作的公司有哪些,dido官方网站?  建站之星代理平台如何选择最佳方案?  网站制作企业,网站的banner和导航栏是指什么?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  定制建站如何定义?其核心优势是什么?  如何通过服务器快速搭建网站?完整步骤解析  如何制作一个表白网站视频,关于勇敢表白的小标题?  网页设计与网站制作内容,怎样注册网站?  江苏网站制作公司有哪些,江苏书法考级官方网站?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  如何有效防御Web建站篡改攻击?  如何高效配置IIS服务器搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。