1. 程式人生 > 程式設計 >使用Javascript開發sliding-nav帶滑動條效果的導航外掛

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

本文介紹如何使用純javascript來開發一款簡單的js外掛,本外掛可以實現滑鼠懸停在導航http://www.cppcns.com上時,下方的滑動條自動從當前選單滑動到所選選單當中去。

本專案的原始碼寄宿於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="高度"

<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屬性)

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

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].ge
程式設計客棧
tAttribute("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.widt程式設計客棧h = 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屬性設www.cppcns.com置成了0.5s,那麼只要在事件裡直接設定該div的如下:

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

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

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,elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });

  }

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

函式作用是給DOM元素繫結滑鼠移入和滑鼠移出事件,具體實現的過程,可以看作者原始碼。

四、所有原始碼

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

for (var j = 0; j < navs[i].children.length; j++) {

   hover(navs[i].children[j],elem) {
    indi.style.width = selected.offsetWidth + "px";
    indi.style.left = selected.offsetLeft + "px";
   });

  }

到此這篇關於使用javascript開發sliding-nav帶滑動條效果的導航外掛的文章就介紹到這了,更多相關js 開發sliding-nav導航條外掛內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!