JS的循环赋class值

JavaScript019

JS的循环赋class值,第1张

js:

window.onload = function(){

    var lis = document.getElementsByTagName("li")

    for (var i = 0 i < lis.length i++) {

        lis[i].className = String(i).length > 1 ? i : "0" + i

    }

}

jquery:

jQuery(function($){

    $("li").each(function(i, domEle){

        $(this).addClass(String(i).length > 1 ? i : "0" + i)

    })

})

关键字:

this

addClass()

removeClass()

当你想为相同的class中的其中一个赋值时,只需要使用关键字this就可以搞定

例:

场景是,点击AAAA被选中的颜色改变,其他不变,想给其中一个点击增加效果,需要使用jquery中addClass方法就好

这里用到this方法,代表我操作点击的这个对象,不能用class中的内容,那样会被全部选中,如果这样写,就会选中A,再选中C时,A不会被清楚

所以要在选中前,先清除下已添加的class

添加多个class 其实可以先从添加一个class然后对其进行封装

好的我废话就不多说了下面给出一份演示

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <style>

 .asdasd{

            width:100px

 height: 100px

 background-color: #cccccc

 }

        .hello{

            background-color: #00AEEF

 }

    </style>

</head>

<body>

<div class="asdasd" id="demo">

</div>

<script>

 //清楚空格

 function trim(str,t){

        if(typeof t == "undefined"){

            t="lr"

 }

        switch (t){

            case "l":{

                return str.replace(/(^\s*)/g, "")

 }

            case "r":{

                return str.replace(/(\s*$)/g, "")

 }

            case "lr":{

                return str.replace(/(^\s*)|(\s*$)/g, "")

 }

        }

    }

    //增加Class

 function addClass(ele,cls){

        if(!ele.getAttribute)return

 var allClass=[]

 cls=trim(cls)

 if(ele.getAttribute("class") == null){}else{

            allClass=ele.getAttribute("class").split(" ")

 }

        if(!inArr(allClass,cls)){

            allClass.push(cls)

 ele.setAttribute("class",allClass.join(" "))

 }

    }

    //循环

 function each(arr,f){

        if(!arr.length)return console.log("error:array is not length")

 for(var i = 0i<arr.lengthi++){

            f.call(arr[i],i,arr[i])

 }

    }

    //是否在数组里面 其实可以通过indexof判断但是indexof是匹配了数据类型的

 function inArr(arr,v){

        if(!arr.length)return false

 for(var i = 0i<arr.lengthi++){

            if(v==arr[i]){return true}

        }

        return false

 }

    //增加多个Class

 function  addClassArr(ele,arr){

       each(arr,function(){

           addClass(ele,this)

 })

   }

    addClassArr(document.getElementById("demo"),["a1","hello","world"])

</script>

</body>

</html>

可以看到 如果没有执行addClassArr这个函数显示的效果的这样的

执行了addClassArr这个函数显示的效果是这样的