js实现给一个标签添加多个class值

在写html跟css的时候,我们会给一些标签起一些class的名字,但是在写js的时候可能也会通过cssName操作css样式,如果只是平常的element.className = "value";的话,那么之前的定义的class会被置空,css中的样式就会受到影响,所以,在js中如果有微调css的话,尽量使用element.style来改变。但是如果真的是使用element.className = "value";的话也可以在js中实现给一个标签添加多个class值,代码如下:

  

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>js 实现给一个标签添加多个class</title>
    <style>
        div{
            width:400px;
            height:60px;
            border:1px solid #000;
        }
        .one{
            background-color: red;
        }
        .two{
            font:italic bold 16px "微软雅黑";
        }
        .three{
            text-align: center;
        }
    </style>
</head>
<body>
    <div id="test">
        js 实现给一个标签添加多个class
    </div>
    <script>
        var test = document.getElementById("test");
        test.className += "one";//属性的className无论有几个值,在js中都是一个字符串,只是有空格而已
        test.className += " two";//后续添加的前边一定要有空格
        test.className += " three";
        alert(test.className); // one two three
        test.className = test.className.replace(/three/,"");//标签有多个class值的时候,删除指定的class
        alert(test.className);//one two
    </script>
</body>
</html>
js 实现给一个标签添加多个class值

typeof  element.className;//String

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。