JS實(shí)現(xiàn)導(dǎo)航欄樓層特效
本文實(shí)例為大家分享了JS實(shí)現(xiàn)導(dǎo)航欄樓層的具體代碼,供大家參考,具體內(nèi)容如下
知識(shí)點(diǎn)
1.多個(gè)事件有沖突的時(shí)候,需要設(shè)置flag判斷是什么事件,進(jìn)而進(jìn)行后續(xù)操作。
2.樓層效果就是判斷scrollTop和offsetTop的關(guān)系
3.引入工具庫(kù)工具庫(kù)
運(yùn)行效果
導(dǎo)航與界面實(shí)現(xiàn)互動(dòng)
代碼
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
*{margin: 0;padding: 0;list-style: none;border:0;}
html, body, ul{width: 100%;height: 100%;}
#ul li{
width: 100%;
height: 100%;
text-align: center;
font-size: 30px;
/*background-color: red;*/
color: #fff;
}
#ol{
width: 80px;
background-color: #ccc;
position: fixed;
left: 50px;
top: 200px;
border: 1px solid #fff;
}
#ol li{
text-align: center;
line-height: 30px;
border-bottom: 1px solid #fff;
color: #fff;
cursor: pointer;
}
#ol li.current{
background-color: orangered;
}
</style>
</head>
<body>
<!--導(dǎo)航-->
<ol id="ol">
<li class="current">第1層</li>
<li>第2層</li>
<li>第3層</li>
<li>第4層</li>
<li>第5層</li>
</ol>
<!--樓層-->
<ul id="ul">
<li>第1層內(nèi)容</li>
<li>第2層內(nèi)容</li>
<li>第3層內(nèi)容</li>
<li>第4層內(nèi)容</li>
<li>第5層內(nèi)容</li>
</ul>
<script src="../../00MyTools/MyTools.js"></script>
<script>
window.addEventListener('load', function (ev) {
// 1. 獲取標(biāo)簽
var ol = myTool.$('ol'), ul = myTool.$('ul');
var ulLis = ul.children;
var olLis = ol.children;
// 是否是點(diǎn)擊產(chǎn)生的滾動(dòng)
var isClick = false;
// 2. 上色
var colorArr = ['red', 'green', 'blue', 'purple', 'yellow'];
for (var i = 0; i < colorArr.length; i++) {
ulLis[i].style.backgroundColor = colorArr[i];
}
// 3. 監(jiān)聽(tīng)導(dǎo)航點(diǎn)擊
for (var j = 0; j < olLis.length; j++) {
var olLi = olLis[j];
(function (index) {
olLi.addEventListener('click', function () {
isClick = true;
for (var i = 0; i < olLis.length; i++) {
olLis[i].className = '';
}
this.className = 'current';
// document.documentElement.scrollTop = index * myTool.client().height;
myTool.slowMoving(document.documentElement, {'scrollTop': index * myTool.client().height}, function () {
isClick = false;
});
});
})(j)
}
// 4. 監(jiān)聽(tīng)滾動(dòng)
var roll = 0;
window.addEventListener('scroll', function (ev1) {
if(!isClick){
// 4.1 獲取頭部滾動(dòng)偏移的高度
roll = Math.ceil(Number(myTool.scroll().top));
// 4.2 遍歷
for (var i = 0; i < ulLis.length; i++) {
// 4.3 判斷
if(roll >= ulLis[i].offsetTop){
for (var j = 0; j < olLis.length; j++) {
olLis[j].className = '';
}
olLis[i].className = 'current';
}
}
}
})
});
</script>
</body>
</html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:JavaScript 實(shí)現(xiàn)HTML DOM增刪改查操作的常見(jiàn)方法詳解
欄 目:JavaScript
本文標(biāo)題:JS實(shí)現(xiàn)導(dǎo)航欄樓層特效
本文地址:http://www.jygsgssxh.com/a1/JavaScript/9325.html
您可能感興趣的文章
- 04-02java菜單欄代碼 java菜單怎么寫
- 04-02java后端代碼分頁(yè) java后端實(shí)現(xiàn)分頁(yè)page
- 01-10Echarts實(shí)現(xiàn)單條折線可拖拽效果
- 01-10在Vue項(xiàng)目中使用Typescript的實(shí)現(xiàn)
- 01-10js實(shí)現(xiàn)上傳圖片并顯示圖片名稱
- 01-10Vue中使用Lodop插件實(shí)現(xiàn)打印功能的簡(jiǎn)單方法
- 01-10echarts實(shí)現(xiàn)折線圖的拖拽效果
- 01-10d3.js實(shí)現(xiàn)圖形縮放平移
- 01-10小程序簡(jiǎn)單兩欄瀑布流效果的實(shí)現(xiàn)
- 01-10H5實(shí)現(xiàn)手機(jī)拍照和選擇上傳功能


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁(yè)面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載


