美文网首页
原生js实现增加删除class(toggleClass)

原生js实现增加删除class(toggleClass)

作者: 啊啊啊阿南 | 来源:发表于2018-10-23 14:39 被阅读0次

原生js实现增加删除class(addClass,removeClass,toggleClass)

//判断样式是否存在
function hasClass(ele, cls) {
    return ele.className.match(new RegExp("(\\s|^)" + cls + "(\\s|$)"));
}
//为指定的dom元素添加样式
function addClass(ele, cls) {
    if (!this.hasClass(ele, cls)) ele.className += " " + cls;
}
//删除指定dom元素的样式
function removeClass(ele, cls) {
    if (hasClass(ele, cls)) {
        var reg = new RegExp("(\\s|^)" + cls + "(\\s|$)");
        ele.className = ele.className.replace(reg, " ");
    }
}
//如果存在(不存在),就删除(添加)一个样式
function toggleClass(ele,cls){ 
    if(hasClass(ele,cls)){ 
        removeClass(ele, cls); 
    }else{ 
        addClass(ele, cls); 
    } 
}
//调用
function toggleClassTest(){ 
    var ele = document. getElementsByTagName('body')[0]; 
    toggleClass(ele,"night-mode"); 
} 

参考 https://www.cnblogs.com/komayyy/p/6402021.html

相关文章

网友评论

      本文标题:原生js实现增加删除class(toggleClass)

      本文链接:https://www.haomeiwen.com/subject/kvcazftx.html