js 动态添加多个class

<!-- <!DOCTYPE HTML> 
<HTML> 
<HEAD> 
<meta charset="utf-8" /> 
<title>setAttribute('class', 'abc')</title> 
<style type="text/css"> 
.ddddd { 
background: black; 

.abc { 
background: red; 

</style> 
</HEAD> 
<BODY> 
<div id="d1" class="ddddd">test div</div> 
<script> 
var div = document.getElementById('d1'); 
// div.setAttribute("class", "abc"); 
div.className+=" "+'abc'  
</script> 
</BODY> 
</HTML>  -->












<html>
  <head>
 
    <style type="text/css">
 
      .div2{
 
      font-size:16px; 
 
      color:orange;
 
      }
 
      .div3{
 
      font-size:20px;
 
      color:blue;
 
      }
 
    </style>
 
    <script type="text/javascript">
 
      [1]直接把样式赋值给className
 
      var odiv=document.getElementById('div1');
 
      odiv.className= 'div3'
 
      //这样我们会得到 class ="div3" 会直接把div2样式给覆盖掉;
 
      [2]使用累加赋值给className
 
      var odiv=document.getElementById('div1');
 
      odiv.className+=" "+'div3'    //样式和样式之间需要空隙 ,所以加个空字符串隔开
 
      //这样可以得到 class="div2 div3" 可以正常增加,但是我们在添加样式的时候我们得考虑下他本身之前有没有同名的样式,如果有我们添加的话就会变成累赘 比如class="div2 div3 div3";
 
      [3]检测样式原先之前是否有相同的样式
 
      var odiv=document.getElementById('div1'); 
 
      function hasClass(element,csName){
 
        element.className.match(RegExp('(\\s|^)'+csName+'(\\s|$)')); //使用正则检测是否有相同的样式
 
  
 
    }  
 
      [4]在[3]的基础上我们就可以进行判断性给元素添加样式了     
 
      var odiv=document.getElementById('div1'); 
 
      function hasClass(element,csName){
 
       return  element.className.match(RegExp('(\\s|^)'+csName+'(\\s|$)')); //使用正则检测是否有相同的样式
 
    } 
 
      function addClass(element,csName){
 
       if(!hasClass(element,csName)){
 
         element.className+=' '+csName;
 
      }
 
    addClass(odiv,'div3');
 
    //这样就可以灵活给元素添加样式了;
 
    【元素删除指定样式】
 
  //同样先进行判断,在进行删除
 
  
 
     var odiv=document.getElementById('div1'); 
 
     function hasClass(element,csName){
 
       return  element.className.match(RegExp('(\\s|^)'+csName+'(\\s|$)')); //使用正则检测是否有相同的样式
 
    } 
 
     function deleteClass(element,csName){
 
       if(!hasClass(element,csName)){
 
         element.className.replace(RegExp('(\\s|^)'+csName+'(\\s|$)'),' ');  //利用正则捕获到要删除的样式的名称,然后把他替换成一个空白字符串,就相当于删除了
 
     }
 
 
 deleteClass(odiv,div3);
  
 
  }
 
    </script>
 
  </head>
 
  <body>
 
    <div id="div1" class='div2'> 测试</div>
 
  </body>
 
</html>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值