本文分为两部分进行讲解,具体内容如下
第一部分:
原生js实现addClass,removeClass,hasClass方法function addClass(ele,cls) {
if (!hasClass(elem,cls)) {
ele.className = ele.className == '' ? cls : ele.className + ' ' + cls;
}
}
if (!hasClass(elem,cls)) {
ele.className = ele.className == '' ? cls : ele.className + ' ' + cls;
}
}
function removeClass(ele,cls) {
if (hasClass(elem,cls)) {
var newClass = ' ' + elem.className.replace(/[\t\r\n]/g,'') + ' ';
while (newClass.indexOf(' ' + cls + ' ') >= 0) {
newClass = newClass.replace(' ' + cls + ' ',' ');
}
elem.className = newClass.replace(/^\s+|\s+$/g,'');
}
}
第二部分:
使用原生JS实现jQuery的addClass,hasClass函数功能function removeClass(obj,cls){
var obj_class = ' '+obj.className+' ';//获取 class 内容,并在首尾各加一个空格. ex) 'abc bcd' -> ' abc bcd '
obj_class = obj_class.replace(/(\s+)/gi,' '),//将多余的空字符替换成一个空格. ex) ' abc bcd ' -> ' abc bcd '
removed = obj_class.replace(' '+cls+' ',' ');//在原来的 class 替换掉首尾加了空格的 class. ex) ' abc bcd ' -> 'bcd '
removed = removed.replace(/(^\s+)|(\s+$)/g,'');//去掉首尾空格. ex) 'bcd ' -> 'bcd'
obj.className = removed;//替换原来的 class.
}
var obj_class = ' '+obj.className+' ';//获取 class 内容,并在首尾各加一个空格. ex) 'abc bcd' -> ' abc bcd '
obj_class = obj_class.replace(/(\s+)/gi,' '),//将多余的空字符替换成一个空格. ex) ' abc bcd ' -> ' abc bcd '
removed = obj_class.replace(' '+cls+' ',' ');//在原来的 class 替换掉首尾加了空格的 class. ex) ' abc bcd ' -> 'bcd '
removed = removed.replace(/(^\s+)|(\s+$)/g,'');//去掉首尾空格. ex) 'bcd ' -> 'bcd'
obj.className = removed;//替换原来的 class.
}
function hasClass(obj,//获取 class 内容.
obj_class_lst = obj_class.split(/\s+/);//通过split空字符将cls转换成数组.
x = 0;
for(x in obj_class_lst) {
if(obj_class_lst[x] == cls) {//循环数组,判断是否包含cls
return true;
}
}
return false;
}
以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。