JavaScript Removeclass addClass 简单封装
来源:互联网 发布:unity3d 四元数 编辑:程序博客网 时间:2024/05/18 08:48
对于JavaScript增删改查对于学习编程后期也是很重要的,
我相信刚刚上手js的,都对于js的数组,字符串方法使用都不够灵活,
特别是for循环的双重嵌套,这一方面我承认我自己也是弱项,
发现上网查嵌套都很少资料 ..所以只能靠自己硬生生写下..
这是我对添加和删除类名简单的做一个封装..
<div id="box" class="warp on"></div>
<script>/* 提示:
1.初始值没有className的时候,拼接不能有空格 ;
2.出现的className不能有重名;
3.比较,有重复的除掉
*/
/*
1.获取初始值className;
2.变量获取:将初始值进行切割;
3.变量获取输入值进行切割;
4.合并初始值和输入值 ;
5.进行查重 遍历合并值
6.倒遍历查重去(不会改变顺序)
*/
调用格式:("类名,ID名,"添加/删除"");
function className(Elements,Cname) {
var Elemens=document.querySelector(Elements),
arr=Elemens.className.split(" "), //将原有的初始className 进行切割
arr1=Cname.split(" "), //将输入的className切割
arr2=arr1.concat(arr); //合并;
for(var i=0; i<arr2.length; i++)
{
for (var j=arr2.length-1; j>i; j--) { //倒遍历
if (arr2[i] == arr2[j]) //如果arr2里面有跟输入的值相同
{
arr2.splice(j,1); //删除
}
}
}
Elemens.className=arr2.join(" "); //将排除的值赋予拼接输出;
}
function removeClass(Elements,Cname) {
var Elemens=document.querySelector(Elements),
arr=Elemens.className.split(" ");
arr1=Cname.split(" ");
for (var i=0; i<arr1.length; i++)
{
for (var j=0; j<arr.length; j++)
{
if (arr1[i]==arr[j])
{
arr.splice(j,1);
}
}
}
Elemens.className=arr.join(" ");
}
0 0
- JavaScript Removeclass addClass 简单封装
- 原生JavaScript addClass() removeClass()
- js封装addClass,removeClass函数
- 原生js封装addClass removeClass hasClass
- 关于JavaScript的addClass,removeClass,hasClass方法
- 原生javascript实现addClass和removeClass
- 原生js封装函数,addClass removeClass,常用tag切换
- jquery hasClass/addClass/removeClass
- js实现addClass,removeClass
- .addClass() 与 .removeClass()
- removeClass addClass解析
- jQuery-addClass()与removeClass()
- 用JS封装的通用addClass方法(函数)和removeClass方法(函数)
- jquery中的addClass(),removeClass(),toggleClass()
- jquery addClass() ,removeClass(),attr(),removeAttr()
- JQuery中.AddClass()和.RemoveClass()
- jQuery中.addClass()和.removeClass()
- jquery hasClass、removeClass、addClass方法
- poj 1258 Agri-Net
- C# 高级知识 事件的标准用法
- Lambda Architecture-大数据处理系统经典架构解析
- docker系列之一 :docker的安装
- [Tomcat] 日常填坑
- JavaScript Removeclass addClass 简单封装
- 让你的mysql表字段支持中文
- 序列化接口Serializable
- 关于php接口中命名空间报错问题:
- NestedScrollView的使用
- poj 1251 jungle roads
- OpenCV On Android环境配置最新&最全指南(Eclipse篇)
- 重写和继承关系中的构造方法
- Matlab coder 踩过的那些坑