前言:

  年后换了工作,在现在的公司写交互主要使用JS原生;刚刚入门前端的时候写交互一直用的原生JS,虽然用的不怎么样。后来去之前的公司之后,leader主张把jQuery用好,JS原生自然就熟练了;一路下来,jQuery用的比较熟练了,但是原生JS反而退步了,很久没用,有的东西都有点手生了;现在的公司用原生JS也挺好的,感觉现在很多新的技术也都基于JS原生;

  做了两个项目,其中对class的DOM操作挺多的,在网上看了很多资料,在别人的基础上总结封装了几个经常用到的函数:getByClass、addClass、removeClass、hasClass;

  原理看看代码,如果不懂看看注释也就没什么大问题。但是,有时候原理看懂了,自己不动手去做一下,就不会发现自己的问题;容易看懂,但是自己不会写;所以还的多动手~

  下面是几个函数具体的代码:

//获取class
function getByClass(oParent, sClass){
if(oParent.getElementsByClassName){
return oParent.getElementsByClassName(sClass);
}else{
var res = [];
var re = new RegExp(' ' + sClass + ' ', 'i')
var aEle = oParent.getElementsByTagName('*');
for(var i = 0; i < aEle.length; i++){
if(re.test(' ' + aEle[i].className + ' ')){
res.push(aEle[i]);
}
}
return res;
}
} //增加class
function addClass(obj,cls) {
var obj_class=obj.className,//获取class的内容;
blank = ( obj_class != '' ) ? ' ' : '';//判断获取的class是否为空,如果不为空,则添加空格;
added = obj_class + blank + cls;//组合原来的class和需要添加的class,中间加上空格;
obj.className = added;//替换原来的class;
} //移除class
function removeClass(obj,cls){
var obj_class = '' + obj.className + '';//获取class的内容,并在首尾各加一个空格;'abc bcd' -> ' abc bcd '
obj_class = obj_class.replace(/(\s+)/gi,' ');//将多余的空字符替换成一个空格;' abc bcd ' -> ' abc bcd '
removed = obj_class.replace(' '+cls+' ',' ');//在原来的class,替换掉首尾加了空格的class ' abc bcd ' -> 'bcd '
removed = removed.replace(/(^\s+)|(\s+$)/g,'');//去掉首尾空格;'bcd ' -> 'bcd'
obj.className = removed;//替换原来的class;
} //判断是否存在class
function hasClass(obj,cls){
var obj_class = obj.className,//获取class的内容;
obj_class_lst = obj_class.split(/\s+/);//通过split空字符将cls转换成数组
x = 0;
for(x in obj_class_lst){
if ( obj_class_lst[x] == cls ) {
return true;
}
}
return false;
}

  注:1.还是得在工作项目、学习中不断的积累这些经验,经常用到的东西自己封装一个库比较方便;

    2.这些函数最好放在页面底部,特别是getByClass;因为根据页面的加载顺序,会先加载JS,如果写在body前面,会先运行getByClass,后面的内容还没加载,就会出现找不到class的情况,出现报错;

  

原生JS编写getByClass、addClass、removeClass、hasClass的更多相关文章

  1. 原生JavaScript实现的addclass,removeclass,hasclass,toggleclass,getbyclass

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  2. 原生js 用正则实现removeclass hasclass getsclass addclass .

    function getByClass(oParent,sClass){ if(oParent.getElementsByClassName){ return oParent.getElementsB ...

  3. 原生js 实现jquery addClass,removeClass

    代码如下: function hasClass(obj, cls) { let reg = new RegExp("(\\s|^)" + cls + "(\\s|$)&q ...

  4. 关于错位动画的练习,原生js编写

    最近在网上看到一个关于错位动画的文章,感觉非常有趣,便自己练习了一下,文章连接:http://www.w3cplus.com/animation/staggering-animations.html ...

  5. 原生js编写的安全色拾色器

    <html > <head> <meta http-equiv="Content-Type" content="text/html; cha ...

  6. 原生js实现addClass,removeClass,hasClass方法

    function hasClass(elem, cls) { cls = cls || ''; if (cls.replace(/\s/g, '').length == 0) return false ...

  7. html5的classList属性介绍和原生js实现jQuery的addClass,removeClass,hasClass方法

    其实html5已经扩展了class操作的相关API,其中classList属性就以及实现了class的增删和判断. classList属性的方法有: add(value) 添加类名,如果有则不添加 c ...

  8. 使用原生JS编写ajax操作XMLHttpRequst对象

    ajax其本质就是XMLHttpRequest,现在jquery调用异步的方法很方便,但是也不能忘记原生的JS去编写ajax; 需要注意的是,很多人在写的时候喜欢只用XMLHttpRequest对象r ...

  9. 原生JS编写的照片墙效果实例演示特效

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. dotnet core2常用命令

    dotnet --info 来查看是否安装成功dotnet new -alldotnet new mvc 创建MVC项目dotnet new more 查看项目类型dotnet restore (恢复 ...

  2. PHP curl 上传文件版本兼容问题

    [摘要:做微疑开辟挪用微疑接心上传文件时,总是返回 {"errcode":41005,"errmsg":"media data missing hin ...

  3. CH6201走廊泼水节

    题目链接: CH6201 [简化版题意]给定一棵N个节点的树,要求增加若干条边,把这棵树扩充为完全图,并满足图的唯一最小生成树仍然是这棵树.求增加的边的权值总和最小是多少. 输入格式 本题为多组数据~ ...

  4. hive join的三种优化方式

    原网址:https://blog.csdn.net/liyaohhh/article/details/50697519 hive在实际的应用过程中,大部份分情况都会涉及到不同的表格的连接, 例如在进行 ...

  5. 批量自动化生成PDF目录标签

    所需软件: 1. FreePic2Pdf(网上很容易找到) 2. python3 3. 天若OCR 链接:https://pan.baidu.com/s/1B9dUr3gc0pv0BSHo5QYGsQ ...

  6. PPT免费模板网站

    OfficePlus|微软PPT官方模版库 优品PPT 稻壳儿

  7. DFS-20190206

    找出所有方案 排列和组合问题 排列: https://www.lintcode.com/problem/combination-sum/description public class Solutio ...

  8. Ubuntu下的RabbitMQ安装与web管理配置

    首先在Ubutnu的/etc/apt/sources.list文件中加入一行 deb http://cz.archive.ubuntu.com/ubuntu trusty main 然后执行 sudo ...

  9. An internal error occurred during: "Initializing Java Tooling". Eclipse启动发生的错误

    An internal error occurred during: “Initializing Java Tooling” 错误经常是莫名其妙的出现这种总错误,解决办法: 1.eclipse -&g ...

  10. Mac开发利器之程序员编辑器MacVim学习总结(转)

    一.关于Vim   Emacs和Vim都是程序员专用编辑器,Emacs被称为神的编辑器,Vim则是编辑器之神.至于两者到底哪个更好用,网络上两大派系至今还争论不休.不过,相比之下,Emacs更加复杂, ...