遍历class

一般国外的网站很注重细节,他们会把菜单或者button做成图片,并且还有hover和selected状态。

 

如果仅仅是单独的button,可以addClass("xx")或者removeClass("xx"),xx是固定值,

但是对于一组菜单或者button,这个时候需要动态地给每个标签加一个对应状态的class,来控制显示样式。

例如下面这样:

<ul>
      <li class="logo1">logo1</li>
      <li class="logo2">logo2</li>
      <li class="logo3">logo3</li>
</ul>

selected的时候:

<ul>
      <li class="logo1 logo1-selected">logo1</li>
      <li class="logo2">logo2</li>
      <li class="logo3">logo3</li>
 </ul>

 hover的时候:

<ul>
      <li class="logo1 logo1-selected logo1-hover">logo1</li>
      <li class="logo2">logo2</li>
      <li class="logo3">logo3</li>
 </ul>
 
<script type="text/javascript">
    $(function(){
      $("ul li").each(function(){
		var currentClass = $(this).attr("class");
		$(this).hover(
		function(){
			removeHover();
			$(this).addClass(currentClass+"-hover");
		},
		function(){
			removeHover();
		}
	    )
        $(this).click(function(){
		  removeHoverSelected()
          $(this).addClass(currentClass+"-selected");
        })
      })
    })
	function removeHover(){
		 $("ul li").each(function(){
            var classNames = $(this).attr("class").split(" ");
            for(var i = 0;i<classNames.length;i++){
              if(classNames[i].indexOf("hover") > -1){
                $("ul li").removeClass(classNames[i]);
              } 
            }
          })  
	}

	function removeHoverSelected(){
		 $("ul li").each(function(){
            var classNames = $(this).attr("class").split(" ");
            for(var i = 0;i<classNames.length;i++){
              if(classNames[i].indexOf("selected") > -1 || classNames[i].indexOf("hover") > -1){
                $("ul li").removeClass(classNames[i]);
              } 
            }
          })  
	}
  </script>

这种方法对N个元素的菜单组或者button组都适用。

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值