zoukankan      html  css  js  c++  java
  • 精简菜单和完整菜单之间进行切换

    初始显示精简菜单:


    点击显示所有品牌之后,将隐藏的品牌显示,并高亮显示推荐的品牌,而且此时button的文字变为“显示精简品牌”


    show you code:

    <!doctype html>
    <html>
    <head>
    <meta charset="utf-8">
    <title>jquery test</title>
    <script src="jquery-1.11.1.min.js"></script>
    <style type="text/css">
    .category
    {
    	clear:both;
    	float:left;
    }
    .category ul li
    {
    	300px;
    	height:50px;
    	float:left;
    	list-style:none;
    }
    .showmore a span
    {
    	margin-left:40%;
    	display:inline-block;
    	margin-top:50px;
    	background-color:#1ABC9C;
    	padding-top:20px;
    	padding-left:100px;
    	200px;
    	height:50px;
    	border:1px black solid;
    }
    .highlight
    {
    	color:red;
    }
    </style>
    </head>
    
    <body>
    <div class="category">
    <ul>
    <li>索尼</li>
    <li>爱立信</li>
    <li>华为</li>
    <li>苹果</li>
    <li>三星</li>
    <li>中兴</li>
    <li>联想</li>
    <li>富士</li>
    <li>可达</li>
    <li>雅马哈</li>
    <li>其它品牌</li>
    </ul>
    </div>
    <br/>
    <div class="showmore">
    <a href=""><span>显示所有品牌</span></a>
    </div>
    <script type="text/javascript">
    	var $category  = $(".category ul li:gt(6):not(:last)");
    	$category.hide();
    	var $togglebtn = $(".showmore a");
    	$togglebtn.click(function(){
    		if($category.is(":visible")){
    			 $category.hide();
    			 $togglebtn.html("<span>显示所有品牌</span>");
    			 $("ul li").removeClass("highlight");
    		}else{
    			 $category.show();
    			 $togglebtn.html("<span>显示精简品牌</span>");
    			 $("ul li").filter(":contains('苹果'),:contains('华为'),:contains('三星')").addClass("highlight");
    		}
    		return false;
    	});
    </script>
    </body>
    </html>
    

    我们首先通过以下的语句获得须要动态显示和隐藏的元素;

    	var $category  = $(".category ul li:gt(6):not(:last)");

    并在初始状态下将其隐藏

           $category.hide();

    然后获取超级链接元素:

    	var $togglebtn = $(".showmore a");
    然后对超链接元素加入click事件,在click触发的函数值中先推断$category部分是否显示

    假设显示,则隐藏之。并去掉高亮显示的品牌。改动超链接内容

    假设隐藏,则显示之,并为推荐品牌加入高亮属性。改动超链接内容。

    由于click触发的事件中的if和else是交替运行的。所以我们能够使用toggle(event)函数进行优化。可是要说明的是:toggle(event)方法在jquery1.9之后的版本号就被废弃了,原因不明~


  • 相关阅读:
    [PA2014]Muzeum
    [AMPPZ2014]Jaskinia
    [PA2015]Rozstaw szyn
    LOJ 6713 「EC Final 2019」狄利克雷 k 次根 加强版
    Problem. R
    51nod 2583 数论只会Gcd
    51nod 1847 奇怪的数学题
    51nod 1575 Gcd and Lcm
    Problem. Q
    CF868G El Toll Caves
  • 原文地址:https://www.cnblogs.com/wzjhoutai/p/6755221.html
Copyright © 2011-2022 走看看