原生JS实现addClass,removeClass,toggleClass

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了原生JS实现addClass,removeClass,toggleClass相关的知识,希望对你有一定的参考价值。

<style type="text/css">
    div.testClass{
        background-color:gray;
    }
</style>

<script type="text/javascript">
function hasClass(obj, cls) {
    return obj.className.match(new RegExp((\\s|^) + cls + (\\s|$)));
}

function addClass(obj, cls) {
    if (!this.hasClass(obj, cls)) obj.className += " " + cls;
}

function removeClass(obj, cls) {
    if (hasClass(obj, cls)) {
        var reg = new RegExp((\\s|^) + cls + (\\s|$));
        obj.className = obj.className.replace(reg,  );
    }
}

function toggleClass(obj,cls){
    if(hasClass(obj,cls)){
        removeClass(obj, cls);
    }else{
        addClass(obj, cls);
    }
}

function toggleClassTest(){
    var obj = document. getElementById(test);
    toggleClass(obj,"testClass");
}
</script>

<body>
    <div id = "test" style = "width:250px;height:100px;">
        sssssssssssss
    </div>
    <input type = "button" value = "toggleClassTest" onclick = "toggleClassTest();" />
</body>

1.addClass:为指定的dom元素添加样式

2.removeClass:删除指定dom元素的样式

3.toggleClass:如果存在(不存在),就删除(添加)一个样式

4.hasClass:判断样式是否存在

以上是关于原生JS实现addClass,removeClass,toggleClass的主要内容,如果未能解决你的问题,请参考以下文章

原生JS实现addClass,removeClass,toggleClass

原生JS实现JQuery的addClass和removeClass

原生JS实现hasClass,addClass,removeClass

js实现addClass添加样式

原生js实现增加(addclass),删除(removeclass),判断是否存在(hasclass),如果存在删除,如果不存在添加(toggleclass)和获取类名(getbyclass)的方法(

原生js :removeClass和addClass