前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript给元素添加多个class的简单实现

JavaScript给元素添加多个class的简单实现

作者头像
浩Coding
发布2019-08-26 10:21:03
4.2K0
发布2019-08-26 10:21:03
举报
文章被收录于专栏:浩Coding

当div 中的class 有多个classname时,它会同时应用这几个class定义的CSS样式,那么应用时的优先级是怎么样的?

如果有多个样式的话,会采取覆盖的形式执行。就是如果有定义同一个属性比如background,后面定义的background属性会覆盖前面的background属性,下面是用JavaScript给元素添加多个class的简单实现的一个例子。

代码语言:javascript
复制
<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>

文章来源:

javaScript给元素添加多个class的简单实现

https://www.jb51.net/article/88901.htm

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 浩Coding 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • javaScript给元素添加多个class的简单实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档