jQuery简单导航条的实现



示例代码:

  1. <head>  
  2.     <title>导航条在项目中的应用</title>  
  3.     <script language="javascript" type="text/javascript"   
  4.             src="../Jscript/jquery-1.5.2.js"></script>  
  5.     <style>  
  6.          body{font-size:13px}  
  7.          #divFrame{border:solid 1px #666;width:301px;overflow:hidden}  
  8.          #divFrame .clsHead{background-color:#eee;padding:8px;height:18px;cursor:hand}  
  9.          #divFrame .clsHead h3{padding:0px;margin:0px;float:left}  
  10.          #divFrame .clsHead span{float:right;margin-top:3px}  
  11.          #divFrame .clsContent{padding:8px}  
  12.          #divFrame .clsContent ul {list-style-type:none;margin:0px;padding:0px}  
  13.          #divFrame .clsContent ul li{ float:left;width:95px;height:23px;line-height:23px}  
  14.          #divFrame .clsBot{float:right;padding-top:5px;padding-bottom:5px}  
  15.          .GetFocus{background-color:#eee}  
  16.     </style>  
  17.     <script type="text/javascript">  
  18.             $(function(){ //页面加载事件  
  19.               $(".clsHead").click(function(){ //图片点击事件  
  20.                 if($(".clsContent").is(":visible")){ //如果内容可见  
  21.                    $(".clsHead span img").attr("src","../Images/a1.gif"); //改变图片  
  22.                    $(".clsContent").css("display","none"); //隐藏内容   
  23.                 }else{  
  24.                    $(".clsHead span img").attr("src","../Images/a2.gif"); //改变图片  
  25.                    $(".clsContent").css("display","block");//显示内容  
  26.                 }  
  27.               });  
  28.                   
  29.               $(".clsBot > a").click(function(){ //热点链接点击事件  
  30.                 if($(".clsBot > a").text()=="简化"){ //如果内容为'简化'字样  
  31.                    $("ul li:gt(4):not(:last)").hide(); //隐藏index号大于4且不是最后一项的元素  
  32.                    $(".clsBot > a").text("更多"); //将字符内容更改为"更多"  
  33.                 }else{  
  34.                    $("ul li:gt(4):not(:last)").show().addClass("GetFocus"); //显示所选元素且增加样式  
  35.                    $(".clsBot > a").text("简化"); //将字符内容更改为"简化"  
  36.                 }  
  37.               });    
  38.             });  
  39.     </script>  
  40. </head>  
  41. <body>  
  42.      <div id="divFrame">  
  43.          <div class="clsHead">  
  44.               <h3>图书分类</h3>  
  45.               <span><img src="../Images/a2.gif" alt=""/></span>  
  46.          </div>  
  47.          <div class="clsContent">  
  48.           <ul>  
  49.              <li><a href="#">小说</a><i> ( 1110 ) </i></li>  
  50.              <li><a href="#">文艺</a><i> ( 230 ) </i></li>  
  51.              <li><a href="#">青春</a><i> ( 1430 ) </i></li>  
  52.              <li><a href="#">少儿</a><i> ( 1560 ) </i></li>  
  53.              <li><a href="#">生活</a><i> ( 870 ) </i></li>  
  54.              <li><a href="#">社科</a><i> ( 1460 ) </i></li>  
  55.              <li><a href="#">管理</a><i> ( 1450 ) </i></li>  
  56.              <li><a href="#">计算机</a><i> ( 1780 ) </i></li>  
  57.              <li><a href="#">教育</a><i> ( 930 ) </i></li>  
  58.              <li><a href="#">工具书</a><i> ( 3450 ) </i></li>  
  59.              <li><a href="#">引进版</a><i> ( 980 ) </i></li>  
  60.              <li><a href="#">其它类</a><i> ( 3230 ) </i></li>  
  61.           </ul>  
  62.          <div class="clsBot"><a href="#">简化</a><img src="../Images/a5.gif" alt=""/></div>  
  63.          </div>  
  64.      </div>  
  65. </body>  
  66. </html>  
说明:在上面的代码中,首先通过$(".clsContent").css("display","none");获取类名称为"clsContent"的元素对象集合,并实现对其内容的隐藏和显示。
  1. $(".clsHead span img").attr("src","../Images/a1.gif");  .clsHead span img 表示获取类型clsHead中<span>标记下<img>标记,即图片元素。  
  2. attr(key,value)是jquery中一个设置元素属性的函数。其功能是为所匹配的元素设置属性值,key是属性的名称,value是属性值或内容。因此这行代码的主要作用是获取图片  
  3. 元素并改变图片的来源。  
 
  1. if($(".clsContent").is(":visible"))//用来检查当前内容的状态。  
 
  1. if($(".clsBot > a").text()=="简化")// 在超链接事件中,检查单击的是“简化”or “更多”。  
  2. 其中$(".clsBot > a")用来获取超链接元素,text()是获取元素内容的函数。  
 
  1. $("ul li:gt(4):not(:last)").hide(); //隐藏index号大于4且不是最后一项的元素   两个并列的过来选择条件。 

相关内容