欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Javascript開發(fā)sliding-nav帶滑動條效果的導(dǎo)航插件

 更新時間:2021年03月29日 11:36:30   作者:dosboy  
這篇文章主要介紹了使用Javascript開發(fā)sliding-nav帶滑動條效果的導(dǎo)航插件,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

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

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

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

一、前言

效果如下圖:

二、使用方法

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

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

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

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

<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>

三、開發(fā)過程

1. 模型示例

導(dǎo)航菜單一般使用上圖的層次型結(jié)構(gòu),外層容器使用<ul> 標記,菜單項使用<li>標記,假設(shè)如果要顯示黃色小橫條,如何定位很重要。

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

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

那么我們?nèi)绾巫屝l看起來在菜單項的正下方呢?

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

實現(xiàn)上面的功能可以使用如下的代碼:

function init() {
 
 var navs = document.getElementsByClassName('sliding-nav');
 
 for (var i = 0; i < navs.length; i++) {
 
 
  //創(chuàng)建一個DIV與當(dāng)前導(dǎo)航豎向?qū)R
  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"
 
  //查找當(dāng)前子菜單項,如果有類名active或者是selected就視為當(dāng)前項,如果沒有使用第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]);
 
  //未完成,下面插入代碼以綁定事件
 
 }
 
}

如上的代碼構(gòu)建了初始化函數(shù)init(),此函數(shù):

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

2、事件與動畫

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

  • left屬性就可以實現(xiàn)"指示條"的移動
  • width屬性就可以設(shè)置"指示條"的寬度

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

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";

   });

   //移出導(dǎo)航就恢復(fù)默認
   hover(navs[i], null, function(e, elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });

  }

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

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

四、所有原代碼

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

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";

   });

   //移出導(dǎo)航就恢復(fù)默認
   hover(navs[i], null, function(e, elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });

  }

到此這篇關(guān)于使用Javascript開發(fā)sliding-nav帶滑動條效果的導(dǎo)航插件的文章就介紹到這了,更多相關(guān)js 開發(fā)sliding-nav導(dǎo)航條插件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript實現(xiàn)圖片DIV豎向滑動的方法

    JavaScript實現(xiàn)圖片DIV豎向滑動的方法

    這篇文章主要介紹了JavaScript實現(xiàn)圖片DIV豎向滑動的方法,涉及javascript操作div層的相關(guān)技巧,需要的朋友可以參考下
    2015-04-04
  • 跟我學(xué)習(xí)javascript的循環(huán)

    跟我學(xué)習(xí)javascript的循環(huán)

    跟我學(xué)習(xí)javascript的循環(huán),本文不僅針對javascript循環(huán)進行講解,還對prototype補充了幾點小tips,歡迎大家閱讀。
    2015-11-11
  • JavaScript刪除字符串中指定字符的4種方法匯總

    JavaScript刪除字符串中指定字符的4種方法匯總

    在前端面試中,經(jīng)常會問到這樣的一個問題,刪除字符串中指定字符,下面這篇文章主要給大家介紹了關(guān)于JavaScript刪除字符串中指定字符的4種方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • 基于JavaScript實現(xiàn)瀑布流效果

    基于JavaScript實現(xiàn)瀑布流效果

    這篇文章主要為大家詳細介紹了基于JavaScript實現(xiàn)瀑布流效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • layui之select的option疊加問題的解決方法

    layui之select的option疊加問題的解決方法

    下面小編就為大家分享一篇layui之select的option疊加問題的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • javascript實現(xiàn)復(fù)制與粘貼操作實例

    javascript實現(xiàn)復(fù)制與粘貼操作實例

    這篇文章主要介紹了javascript實現(xiàn)復(fù)制與粘貼操作,以實例形式講述了javascript實現(xiàn)復(fù)制與粘貼操作的實現(xiàn)方法,需要的朋友可以參考下
    2014-10-10
  • javascript如何讀寫本地sqlite數(shù)據(jù)庫

    javascript如何讀寫本地sqlite數(shù)據(jù)庫

    這篇文章主要介紹了javascript如何讀寫本地sqlite數(shù)據(jù)庫問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 微信小程序+ECharts實現(xiàn)動態(tài)刷新的過程記錄

    微信小程序+ECharts實現(xiàn)動態(tài)刷新的過程記錄

    這篇文章主要給大家介紹了關(guān)于微信小程序+ECharts實現(xiàn)動態(tài)刷新的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • JavaScript面向?qū)ο笾钊肓私釫S6的class

    JavaScript面向?qū)ο笾钊肓私釫S6的class

    class盡管只算是一個語法糖,但它卻是語言規(guī)范方面的一大成就,也對之前的繼承進行了一定的增強,下面這篇文章主要給大家介紹了關(guān)于JavaScript面向?qū)ο笾钊肓私釫S6的class的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • JS實現(xiàn)簡單的拖拽效果

    JS實現(xiàn)簡單的拖拽效果

    拖拽是前端實現(xiàn)中比較常用的一種效果, HTML5 提供了較為強大的拖拽 API 支持,今天我們來實現(xiàn)一個簡單的拖拽效果,需要的朋友可以參考下
    2023-09-09

最新評論