总结:js中4类修改样式的方法
yund56 2025-04-22 08:31 15 浏览
#前言
最近在写一个扩展右键菜单的插件,既然是插件,想着一步到位,把相关的style样式设置都丢进js文件中,直接加载一个js文件便可以使用该插件,所以今天就研究了下js批量的插入样式的方法,即addSheet,顺便总结下Javascript中修改样式的4类方法
#正文
1、通过js动态的创建style对象
直接贴代码更为方便,这是addCssRule方法,可以一条一条规则的添加到样式表中
var addCssRule = (function {
//该方法因为引用了闭包,无论如何都会创建style对象,所以不能做插件使用,需要自己手动修改,目前未进行修改
var createSheet = function {
var style = document.createElement("style");
document.head.appendChild(style);
//后面写法是为了兼容ie8以下
return style.sheet||style.styleSheet;
};
var sheet = createSheet;
return function(selector,rules,index){
var index=index||0;
if(sheet.insertRules){
sheet.insertRules(selector+"{"+rules+"}",index);
}else{
sheet.addRule(selector,rules,index);
}
}
});
该方法的思路就是,通过创建style,并把style添加到head上,然后返回style的sheet对象,利用sheet对象的insertRule(主流),或者addRule(ie8以下)方法,把样式添加到新建的样式表中。当然,此方法也可以改写成添加到已有的样式表中,而无须另行的创建新的样式表。
上面的方法是手动的每条规则添加一次,而我目前的需求是批量的添加样式,所以需要另寻它法。
下面的这个是addSheet方法
var addSheet=function(styleStr){
var styleElements=document.getElementsByTagName("style");
if(styleElements.length==0){
if(document.createStyleSheet){
//说明是ie8,注意,ie8的style通过js创建的话必须使用该方法创建
//如果不使用该方法创建,那么通过createElement("style")方法创建的style对象在ie8下,没有对应的cssText方法
document.createStyleSheet;
//通过该方法创建,会自动添加到head中
}else{
//现代浏览器直接使用createElement
var styleE=document.createElement("style");
document.head.appendChild(styleE);
}
}
//styleElements是类数组,会自动更新
var styleElement=styleElements[0];
if(styleElement.styleSheet){
//说明ie8
styleElement.styleSheet.cssText+=styleStr;
}else{
var textNode = document.createTextNode(styleStr);
styleElement.appendChild(textNode);
}
};
使用实例
addSheet('.dialog{\
width:600px;\
margin:30px auto;\
background-color: #fff;\
box-shadow: 0 3px 9px rgba(0,0,0,0.5);\
font-family: Arial, sans-serif;\
font-size: 13px;\
line-height: 1.4;\
}')
addSheet方法可以批量的插入大量的样式,但是目前的缺点是,由于换行造成了不足,需要手动的在后面加上\解决,所以在实际开发中如果想使用该方法,可以通过网上的工具,把样式进行空格压缩之后作为参数传进来。目前打算是自己写一个node程序撸掉它。
2、使用行内样式
这个方法应该是我们最为熟悉的了,介绍不多
oDiv.style.color="#fff";
oDiv.style.fontSize="14px";
3、使用cssText(注意)
oDiv.style.cssText="color:#fff;font-size:14px;";
在使用该方法时,注意两点,cssText属性会覆盖原来的行内样式,即
<div style="width:100px;"></div>
在使用了
oDiv.style.cssText="color:#fff;font-size:14px;";
之后,原本的样式会被覆盖,变成
<div style="color:#fff;font-size:14px;"></div>
所以,一般我们为了避免行内样式被覆盖,都会这样使用
oDiv.style.cssText+="color:#fff;font-size:14px;";
这样原本的行内样式就不会被覆盖
<div style="width:100px;color:#fff;font-size:14px;"></div>
但是,在ie8之下,却存在一个奇葩的问题
<div style="width:100px;"></div>
console.log(oDiv.style.cssText);
输出结果是这样的width:100px
,如果足够细心你会发现,此处的;被剔除了,所以一旦在ie8以下这样使用cssText则会由于分号的原因出现问题
oDiv.style.cssText+="color:#fff;font-size:14px;";
所以为了在ie8以下正常使用需要写个方法加上分号,具体方法这里不写了,后面的参考博客会给出
4、修改class
总共有4类方法修改样式,其他小的不计在这里,最后的一个方法就是通过修改元素的className来实现,这里也给出几个与class相关的参考方法
getClass方法
var getClass=function(ele){
//使用trim方法格式化一次,防止 red blue yellow 这样的情况
//这里的trim方法不可以去除
ele.className=ele.className.trim;
return ele.className.replace(/\s+/g," ").split(" ");
};
hasClass方法
var hasClass=function(ele,cls){
//下面的这行代码是错误的,由于使用的正则匹配中,需要传参匹配,所以无法使用字面量的正则表达式,因为字面量的正则无法传参,只能用于常量,所以此处需要使用构造函数创建正则
//var reg=/\b+cls+\b/g;
//注意此处的\b变成了\\b,因为要进行双重转义,所以原本的元字符\b都要变成\\b这样的形式
//这里的trim方法可以去除
var cls=cls.trim;
var reg=new RegExp("\\b"+cls+"\\b");
return reg.test(ele.className);
};
addClass方法
var addClass=function(ele,cls){
if(!hasClass(ele,cls)) {
//这里的trim方法可以去除
var cls=cls.trim;
ele.className += " " + cls;
}
};
removeClass方法
var removeClass=function(ele,cls){
if(hasClass(ele,cls)){
//这里的trim方法可以去除
var cls=cls.trim;
var reg=new RegExp("\\b"+cls+"\\b");
return ele.className=ele.className.replace(reg,"")
}
};
剩下的这个replaceClass方法懒得写了
var replaceClass=function(ele,nCls,oCls){
};
上述的代码片段都是看了其他大牛博主,然后自己偷懒少写了一部分功能实现的,所以如果想要在实际开发中使用上面的方法请看下面的参考链接拿到源码,毕竟我上面的那些都是为了测试而写的,不完整。
参考链接
相关推荐
- 如何在Office 中编辑 PDF?附详细化步骤
-
PDF很受欢迎,因为它能在不同的设备和操作系统上仍然保持原有格式。但是,这也意味着直接更改PDF文件比其他格式更难更复杂。值得庆幸的是,Microsoftoffice和UPDF帮你解决这一难题。一...
- 我的 Windows 装机必备软件清单
-
今天给大家分享下我的装机必备软件,都是用了好多年的软件神器。靠谱、好用、无广告,Windows电脑必备软件,收藏这一篇就够了!01.浏览器王者:Chromehttps://www.google.c...
- Docnet Core 是一个轻量级、高性能的 .NET PDF 操作库
-
DocnetCore介绍DocnetCore是一个轻量级、高性能的.NETPDF操作库,依托于PDFium渲染引擎,提供强大的PDF文档解析、渲染、操作等功能。它完全支持.NET...
- 分享三款好用的PDF编辑软件,轻松处理PDF
-
作为一名需要经常和PDF文件打交道的工作者,我来分享一下几款好用的PDF编辑软件,并详细分析了它们的优缺点,希望能帮你找到合适的工具。1.AdobeAcrobatDC作为PDF格式的发明者,Ado...
- PDF文档创建工具软件:novaPDF OEM 11.9 Build 432 for Windows
-
novaPDFOEM是一款实用高效的软件,从头开始设计,让您尽可能轻松地在应用程序中添加PDF打印功能。换句话说,这个实用程序是专门为应用程序开发人员设计的,可以直接在程序安装程序中集成为PDF打印...
- 线性表顺序存储结构求集合的并,交,补,差(源代码附上 超详细)
-
一:算法分析1)用数组A,B,C,E表示集合。假定A={1,3,4,5,6,7,9,10}, B={2,,3,4,7,8,10},E={1,2,3,4,5,6,7,8,9,10}, 输入数组A...
- 分享一套SpringBoot开发博客系统源码,包含完整开发文档和视频
-
基本信息项目名称:eblog摘要:eblog是一个基于Springboot2.1.2开发的博客学习项目,为了让项目融合更多的知识点,达到学习目的,编写了详细的从0到1开发文档。主要学习包括:自定义Fr...
- 通达信指标合集〔源码齐全〕
-
很多朋友问到我哪款指标好用,这里我说一下,之所以有很多不同的指标是因为我们在针对不同的盘面情况的时候使用的指标是不同的,我给到的指标一般来讲就目前的环境来讲都是比较适合的,今天我就把我平时自己常用的指...
- 巅峰对决!Spring Boot VS .NET 6
-
SpringBoot和ASP.NETCore都是企业中流行的Web框架,对于喜欢C#的人会使用ASP.NETCore,而对于Java或Kotlin等基于JVM的语...
- 在asp.net core 中控制访问权限的方法
-
Intro#由于项目需要,需要在基于asp.netmvc的Web项目框架中做权限的控制,于是才有了这个权限控制组件,最初只是支持netframework,后来dotnetcore2.0...
- ASP.NET是否无生存之地?
-
ASP.NET,这个已经很久的技术,总觉得已经被时代淘汰,我们公司是一个10人小公司,几个十年十五年的项目还是用ASP.NET开发的。这两年由于客户的需求变化,我们公司也顺势开始对这些项目重新开发,改...
- Spring Boot + Vue.js 实现前后端分离(附源码)
-
作者:梁小生0101链接:juejin.im/post/5c622fb5e51d457f9f2c2381SpringBoot+Vue.js前后端涉及基本概念介绍,搭建记录,本文会列举出用到环...
- ASP.NET Core 中的 Mapster 使用入门教程
-
在本文中,我们将学习如何在ASP.NETCore应用程序中使用Mapster。首先,我们将了解Mapster是什么以及如何将其安装到.NETCore应用程序中。然后,我们将在使用...
- Asp.net常用方法及request和response-a
-
asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...
- ASP.NET Core使用功能开关控制路由访问
-
前言在前面的文章,我们介绍了使用Middleware有条件地允许访问路由(《ASP.NETCore使用Middleware有条件地允许访问路由》)。而对于一些试验性的功能,我们并不希望用密码去控制是...
- 一周热门
- 最近发表
- 标签列表
-
- filter函数js (37)
- filter函数excel用不了 (73)
- 商城开发 (40)
- 影视网站免费源码最新版 (57)
- 影视资源api接口 (46)
- 网站留言板代码大全 (56)
- java版软件下载 (52)
- java教材电子课本下载 (48)
- 0基础编程从什么开始学 (50)
- java是用来干嘛的 (51)
- it入门应该学什么 (55)
- java线上课程 (55)
- 学java的软件叫什么软件 (38)
- 程序开发软件有哪些 (53)
- 软件培训 (59)
- 机器人编程代码大全 (50)
- 少儿编程教程免费 (45)
- 新代系统编程教学 (61)
- 共创世界编程网站 (38)
- 亲测源码 (36)
- 三角函数积分公式表 (35)
- 函数的表示方法 (34)
- 表格乘法的公式怎么设置 (34)
- sumif函数的例子 (34)
- 图片素材 (36)