国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - 使用Javascript開發sliding-nav帶滑動條效果的導航插件

使用Javascript開發sliding-nav帶滑動條效果的導航插件

2022-02-21 17:00dosboy js教程

這篇文章主要介紹了使用Javascript開發sliding-nav帶滑動條效果的導航插件,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

本文介紹如何使用純Javascript來開發一款簡單的JS插件,本插件可以實現鼠標懸停在導航上時,下方的滑動條自動從當前菜單滑動到所選菜單當中去。

本項目的源代碼寄宿于GitHub,記得點小星星哦:

https://github.com/dosboy0716/sliding-nav

一、前言

效果如下圖:

使用Javascript開發sliding-nav帶滑動條效果的導航插件

二、使用方法

本插件只需要如下的三步,就可以在您的項目中使用:

1、在</body>標記結束前,引用sliding-nav.js文件

2、在需要滑動條的菜單容器上加類名 sliding-nav,當前項使用類名:active

3、使用屬性來定定外觀:sn-color="顏色" sn-radius="圓度" sn-height="高度"

?
1
2
3
4
5
6
<script src="/path/to/sliding-nav.js"></script>
<ul class="nav sliding-nav" sn-color="#F00" sn-radius="0px" sn-height="3px">
 <li class="active">菜單項1</li>
 <li>菜單項2</li>
 <li>菜單項3</li>
<ul>

三、開發過程

1. 模型示例

使用Javascript開發sliding-nav帶滑動條效果的導航插件

導航菜單一般使用上圖的層次型結構,外層容器使用<ul> 標記,菜單項使用<li>標記,假設如果要顯示黃色小橫條,如何定位很重要。

經過分析,雖然在視覺上小橫條位于UL之內,為了不破壞原來導航的樣式,小黃條必須使用absolute的絕對定位,并且初始位置與ul標記相同。

因此,我們把小橫條插入<ul>標記的前面,如上面的小灰點,它就是小橫條的初始位置即(left=0,top=0)的位置。

那么我們如何讓小條看起來在菜單項的正下方呢?

  • 把小條的top屬性賦值為菜單項的高度(即offsetHeight屬性),
  • 把小條的left屬性賦值為菜單項的左邊距(即offsetLeft屬性)

實現上面的功能可以使用如下的代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
function init() {
 
 var navs = document.getElementsByClassName('sliding-nav');
 
 for (var i = 0; i < navs.length; i++) {
 
 
  //創建一個DIV與當前導航豎向對齊
  var indi = document.createElement("div");
  indi.id = "slna-indicator"
 
  indi.style.borderRadius = navs[i].getAttribute("sn-radius") || "0px"
  indi.style.height = navs[i].getAttribute("sn-height") || "3px"
  indi.style.backgroundColor = navs[i].getAttribute("sn-color") || "#F00"
 
  indi.style.position = "absolute"
  indi.style.transition = "0.5s"
 
  //查找當前子菜單項,如果有類名active或者是selected就視為當前項,如果沒有使用第1項
  var selected = navs[i].getElementsByClassName('active')
  if (selected.length == 0) {
   selected = navs[i].getElementsByClassName('selected')
  }
  if (selected.length == 0) {
   selected = navs[i].children
  }
 
  if (selected.length == 0) {
   throw Error('Sorry, Navigation bar has no item at all!');
  }
 
  selected = selected[0];
 
  indi.style.width = selected.offsetWidth + "px";
  indi.style.top = selected.offsetHeight + "px";
  indi.style.left = selected.offsetLeft + "px";
  navs[i].parentElement.insertBefore(indi, navs[i]);
 
  //未完成,下面插入代碼以綁定事件
 
 }
 
}

如上的代碼構建了初始化函數init(),此函數:

查找所有含有類名sliding-nav的標記,并且按照上面的方法,在前面插入div標記充當“指示條”,并且查找“活動”的菜單項,找到后通過這個菜單項的各個屬性給“指示條”定位。

2、事件與動畫

我們把"指示條"div 標記transition屬性設置成了0.5s,那么只要在事件里直接設置該div的如下:

  • left屬性就可以實現"指示條"的移動
  • width屬性就可以設置"指示條"的寬度

所以可以在如上的代碼末尾,插入如下的代碼實現事件與動畫:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
for (var j = 0; j < navs[i].children.length; j++) {
 
   hover(navs[i].children[j], function(e, elem) {
 
    indi.style.width = elem.offsetWidth + "px";
    indi.style.left = elem.offsetLeft + "px";
 
   });
 
   //移出導航就恢復默認
   hover(navs[i], null, function(e, elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });
 
  }

其中代碼,用到了自定義函數hover,該函數類似于實現hover事件,JS原生只有mouseover和mouseout事件。

函數作用是給DOM元素綁定鼠標移入和鼠標移出事件,具體實現的過程,可以看作者原代碼。

四、所有原代碼

本文實現的所有原代碼如下,希望讀者提出更加優化的建議,我們一起打造更加唯美的前端體驗。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
for (var j = 0; j < navs[i].children.length; j++) {
 
   hover(navs[i].children[j], function(e, elem) {
 
    indi.style.width = elem.offsetWidth + "px";
    indi.style.left = elem.offsetLeft + "px";
 
   });
 
   //移出導航就恢復默認
   hover(navs[i], null, function(e, elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });
 
  }

到此這篇關于使用Javascript開發sliding-nav帶滑動條效果的導航插件的文章就介紹到這了,更多相關js 開發sliding-nav導航條插件內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/dosboy/archive/2021/03/28/14590251.html

延伸 · 閱讀

精彩推薦
  • js教程前端如何實現動畫過渡效果

    前端如何實現動畫過渡效果

    這篇文章主要介紹了前端如何實現動畫過渡效果,幫助大家更好的理解和學習前端開發網頁,感興趣的朋友可以了解下...

    donglegend6412022-01-17
  • js教程確保JavaScript 安全的五大做法

    確保JavaScript 安全的五大做法

    如果你運行交互式網站或應用程序,JavaScript 安全性是重中之重。 從程序錯誤和不安全的用戶輸入到惡意攻擊,有很多事情可能會出錯。...

    粵嵌教育8772022-01-11
  • js教程JavaScript 生成唯一ID的幾種方式

    JavaScript 生成唯一ID的幾種方式

    這篇文章主要介紹了JavaScript 生成唯一ID的幾種方式,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    specialCoder5042022-01-21
  • js教程javascript中layim之查找好友查找群組

    javascript中layim之查找好友查找群組

    這篇文章主要介紹了javascript中layim之查找好友查找群組,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    踮腳敲代碼9182022-01-19
  • js教程微信小程序實現登錄注冊功能

    微信小程序實現登錄注冊功能

    這篇文章主要介紹了微信小程序實現登錄注冊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    保護我方豆豆5492021-12-22
  • js教程利用JS十分鐘判斷數組中存在元素的多種方式

    利用JS十分鐘判斷數組中存在元素的多種方式

    這篇文章主要給大家介紹了關于利用JS十分鐘判斷數組中存在元素的多種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考...

    蚊子前端博客5942022-02-12
  • js教程提高JavaScript性能技巧,以獲得更快的網站

    提高JavaScript性能技巧,以獲得更快的網站

    在開發應用程序時,性能是最重要的問題之一,所有軟件開發人員都應該監控和改進應用程序每一層的性能。從數據庫到服務器端語言,出現性能問題的時...

    粵嵌教育7752022-01-11
  • js教程JavaScript中跨域問題的深入理解

    JavaScript中跨域問題的深入理解

    這篇文章主要給大家介紹了關于JavaScript中跨域問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要...

    三七安6792022-02-10
主站蜘蛛池模板: 黄色日本视频 | 亚洲精品国精品久久99热 | 亚洲人人爱 | 亚洲lesbianxxxxhd| 国产精品欧美日韩 | 亚洲精品视频一区二区三区 | 国产激情偷乱视频一区二区三区 | 国产一区在线视频观看 | 876av国产精品电影 | 国产区视频在线观看 | 国产精品一区二区三区在线 | 一区二区免费看 | 久久国产亚洲精品 | 欧美视频免费看 | 国产乱淫精品一区二区三区毛片 | 中国黄色毛片 大片 | 黄色免费观看网站 | 国产一区免费 | 成人午夜精品一区二区三区 | 国产精品久久99 | av一区久久| 国内精品一区二区三区 | 男人的天堂久久 | 日韩精品免费 | 亚洲一区二区在线免费观看 | 91在线视频 | 精品96久久久久久中文字幕无 | 五月激情综合网 | 国产精品美女久久久久aⅴ国产馆 | 亚洲国产精品久久久久久 | 久草热8精品视频在线观看 毛片黄片免费观看 | 欧美亚洲视频在线观看 | 成人国产精品一区二区免费麻豆 | 国产视频在线播放 | 一区二区三区在线免费观看 | 亚洲精品自拍 | www.涩涩视频 | 中文字幕 国产精品 | 久久99精品国产麻豆宅宅 | 亚洲成av人影片在线观看 | 阿v视频在线观看 |