jQuery仿京東商城樓梯式導(dǎo)航定位菜單
本文實現(xiàn)京東商城樓梯式導(dǎo)航定位菜單:滾動定位菜單項和點擊定位菜單項!
涉及知識點:find()、parent()、offset()、scroll()等jQ函數(shù),請自覺復(fù)習(xí)各種函數(shù)!
html代碼:
<!-- 導(dǎo)航菜單 --> <div id="menu"> <ul> <li>1F<span>服飾</span></li> <li>2F<span>美妝</span></li> <li>3F<span>手機</span></li> <li>4F<span>家電</span></li> <li>5F<span>數(shù)碼</span></li> <li>6F<span>運動</span></li> <li>7F<span>居家</span></li> <li>8F<span>母嬰</span></li> <li>9F<span>食品</span></li> <li>10F<span>圖書</span></li> <li>11F<span>服務(wù)</span></li> </ul> </div> <!-- 導(dǎo)航菜單 --> <!-- 產(chǎn)品內(nèi)容 --> <div id="content"> <img src="images/head.png" alt="" style="border:1px solid red;"> <div class="louti" id="louti1"><img src="images/f1.png" alt=""></div> <div class="louti" id="louti2"><img src="images/f2.png" alt=""></div> <div class="louti" id="louti3"><img src="images/f3.png" alt=""></div> <div class="louti" id="louti4"><img src="images/f4.png" alt=""></div> <div class="louti" id="louti5"><img src="images/f5.png" alt=""></div> <div class="louti" id="louti6"><img src="images/f6.png" alt=""></div> <div class="louti" id="louti7"><img src="images/f7.png" alt=""></div> <div class="louti" id="louti8"><img src="images/f8.png" alt=""></div> <div class="louti" id="louti9"><img src="images/f9.png" alt=""></div> <div class="louti" id="louti10"><img src="images/f10.png" alt=""></div> <div class="louti" id="louti11"><img src="images/f11.png" alt=""></div> </div> <!-- 產(chǎn)品內(nèi)容 --> <!-- 底部 --> <div id="footer" class="container"></div>
css代碼:
#menu{ width:32px;height:360px; position:fixed; top:200px;left:0px; display: none; } #menu ul li{ width:32px;height:32px; list-style-type:none; color:#8F8583; text-align:center; line-height: 32px; border-bottom:1px dotted #ddd; position:relative; } #menu ul li span{ display:block;width:32px;height:32px; background:#C81623; position:absolute; top:0;left:0; color:#fff;font-size:12px; display: none; } #menu ul li:hover span{display:block; } #menu ul li span.active{color:#C81623;background:#fff;display:block;} #content{ width:1220px; margin:0 auto; } #footer{width:1220px;height:600px;background:#FE7678;} .container{margin:0 auto;}
jQuery代碼:
$(function(){ var _index=0; $("#menu ul li").click(function(){ $(this).find("span").addClass("active").parent().siblings().find("span").removeClass("active"); _index=$(this).index()+1; //通過拼接字符串獲取元素,再取得相對于文檔的高度 var _top=$("#louti"+_index).offset().top; //scrollTop滾動到對應(yīng)高度 $("body,html").animate({scrollTop:_top},500); }); var nav=$("#menu"); //得到導(dǎo)航對象 var win=$(window); //得到窗口對象 var sc=$(document);//得到document文檔對象。 win.scroll(function(){ if(sc.scrollTop()>=600){ $("#menu").show(); //獲取滾動元素對應(yīng)的索引!!!重難點 var index=Math.floor(sc.scrollTop()/600); $("#menu ul li span").eq(index-1).addClass("active").parent().siblings().find("span").removeClass("active"); }else{ $("#menu").hide(); } }); });
滾動中常用到的jQ寫法:
$("body,html").animate({scrollTop:_top},500);
總結(jié):相對來說,這是個蠻有趣的實踐案例,但其中用到比較多的函數(shù),結(jié)合了本案例比較特殊的html結(jié)構(gòu)設(shè)計,需要理清滾動導(dǎo)航時候的條件判斷。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jQuery實現(xiàn)菜單欄導(dǎo)航效果
- 基于jQuery實現(xiàn)左側(cè)菜單欄可折疊功能
- 最常見的左側(cè)分類菜單欄jQuery實現(xiàn)代碼
- jquery仿京東導(dǎo)航/仿淘寶商城左側(cè)分類導(dǎo)航下拉菜單效果
- 基于jquery實現(xiàn)導(dǎo)航菜單高亮顯示(兩種方法)
- jQuery 實現(xiàn)側(cè)邊浮動導(dǎo)航菜單效果
- jquery實現(xiàn)點擊向下展開菜單項(伸縮導(dǎo)航)效果
- jQuery實現(xiàn)的導(dǎo)航下拉菜單效果示例
- JQuery 寫的個性導(dǎo)航菜單
- jquery實現(xiàn)網(wǎng)頁左側(cè)導(dǎo)航菜單欄
相關(guān)文章
jQuery 1.9.1源碼分析系列(十四)之常用jQuery工具
這篇文章主要介紹了jQuery 1.9.1源碼分析系列(十四)之常用jQuery工具的相關(guān)資料,需要的朋友可以參考下2015-12-12基于jquery實現(xiàn)滾輪放大縮小圖片的函數(shù)代碼
這篇文章主要介紹了基于jquery實現(xiàn)滾輪放大縮小圖片的函數(shù)代碼,需要的朋友可以參考下2023-05-05jQuery通過點擊行來刪除HTML表格行的實現(xiàn)示例
從一個HTML表使用一些時髦的效果,只要按一下該行,改行即可被刪除,這個示例比較簡單,新手朋友們可以學(xué)習(xí)下2014-09-09JQuery設(shè)置和去除disabled屬性的5種方法總結(jié)
下面與大家分享下兩種方法設(shè)置disabled屬性以及三種方法移除disabled屬性,感興趣的朋友可以參考下哈,希望對你有所幫助2013-05-05如何使用jquery easyui創(chuàng)建標(biāo)簽組件
這篇文章主要介紹了如何使用jquery easyui創(chuàng)建標(biāo)簽組件的相關(guān)資料,需要的朋友可以參考下2015-11-11jQuery-1.9.1源碼分析系列(十)事件系統(tǒng)之事件包裝
這篇文章主要介紹了jQuery-1.9.1源碼分析系列(十)事件系統(tǒng)之事件包裝的相關(guān)資料,需要的朋友可以參考下2015-11-11使用element-ui的el-menu導(dǎo)航選中后刷新頁面保持當(dāng)前選中狀態(tài)
這篇文章主要介紹了使用element-ui的el-menu導(dǎo)航選中后刷新頁面保持當(dāng)前選中狀態(tài),本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07學(xué)習(xí)jquery必備 api中英文對照的chm手冊 下載
學(xué)習(xí)jquery必備 api中英文對照的chm手冊 下載...2007-05-05Javascript函數(shù)中的arguments.callee用法實例分析
這篇文章主要介紹了Javascript函數(shù)中的arguments.callee用法,結(jié)合實例形式分析了arguments.callee操作當(dāng)前方法引用的具體技巧,需要的朋友可以參考下2016-09-09