亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript實現(xiàn)精美個性導(dǎo)航欄筋斗云效果

 更新時間:2017年10月29日 17:37:09   作者:Dragonir  
這篇文章主要介紹了JavaScript實現(xiàn)精美個性導(dǎo)航欄筋斗云效果,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

實現(xiàn)效果:

  實現(xiàn)效果如下圖所示

實現(xiàn)原理:

什么是筋斗云效果:

•這個效果很簡單,就是鼠標(biāo)移到其他導(dǎo)航目錄時會有背景圖片跟著鼠標(biāo)滑動到當(dāng)前的目錄。

實現(xiàn)思路:

•鼠標(biāo)經(jīng)過的時候,利用offsetLeft獲得當(dāng)前盒子距離左側(cè)的距離,把這個值賦給緩動動畫的end值。
•當(dāng)點擊的時候記住當(dāng)前的offsetLeft值,當(dāng)鼠標(biāo)經(jīng)過的時候把之前點擊的offsetLeft給現(xiàn)在經(jīng)過時候的值。

實現(xiàn)代碼:

  下面是實現(xiàn)代碼以及詳細注釋,核心設(shè)置一個position為absolute的span標(biāo)簽,通過綁定鼠標(biāo)事件,用封裝好的animate動畫實現(xiàn)span的“筋斗云”效果。

<!DOCTYPE html>
<html>
<head>
  <title>導(dǎo)航欄筋斗云效果</title>
  <meta charset="utf-8">
  <style type="text/css">
    *{
      padding: 0;
      margin: 0;
    }
    body{
      background-color: rgba(0, 0, 0, 0.6);
    }
    .box{
      width: 415px;
      height: 42px;
      margin: 200px auto;
      background-color: #fff;
      position: relative;
    }
    ul{
      list-style: none;
      position: relative;
    }
    li{
      float: left;
      width: 83px;
      height: 42px;
      text-align: center;
      font: 500 15px/42px "微軟雅黑";
      cursor: pointer;
    }
    span{
      position: absolute;
      left: 0;
      top: 0;
      width: 83px;
      height: 42px;
      background-image: linear-gradient(to right,#03c03c 50% ,#51ee5d 100%);
    }
  </style>
</head>
<body>
<div class="box">
  <span></span>
  <ul>
    <li>菜單欄1</li>
    <li>菜單欄2</li>
    <li>菜單欄3</li>
    <li>菜單欄4</li>
    <li>菜單欄5</li>
  </ul>
</div>
<script type="text/javascript">
  window.onload = function(){
    // 鼠標(biāo)放在哪個li上面,span對應(yīng)一道到哪里,移開后回到原位置
    var liArr = document.getElementsByTagName("li");
    var liWidth = liArr[0].offsetWidth;
    var span = document.getElementsByTagName("span")[0];
    // 計數(shù)器
    var cnt = 0;
    // for循環(huán)綁定事件
    for(var i=0; i<liArr.length; i++){
      // 自定義屬性,然后綁定index屬性為索引值
      liArr[i].index = i;
      // 鼠標(biāo)進入事件
      liArr[i].onmouseover = function(){
        // 然span運動到該li的索引值位置
        animate(span, this.index*liWidth);
      }
      // 鼠標(biāo)移開
      liArr[i].onmouseout = function(){
        // span運動到原位置
        animate(span, cnt*liWidth);
      }
      // 點擊事件
      liArr[i].onclick = function(){
        // 計數(shù)器記錄當(dāng)前標(biāo)簽索引值
        cnt = this.index;
        animate(span, cnt*liWidth);
      }
    }
    // 緩動動畫封裝
    function animate(element, target){
      // 清除間歇調(diào)用
      clearInterval(element.timer);
      // 設(shè)置超時調(diào)用
      element.timer = setInterval(function(){
        // 設(shè)置步數(shù)
        var step = (target - element.offsetLeft)/10;
        // 調(diào)整步數(shù)
        step = step > 0 ? Math.ceil(step) : Math.floor(step);
        // 設(shè)置樣式
        element.style.left = element.offsetLeft + step + "px";
        // console.log(1);
        if(Math.abs(target - element.offsetLeft) < Math.abs(step)){
          element.style.left = target + "px";
          clearInterval(element.timer);
        }
      }, 20);
    }
  }
</script>
</body>
</html> 

總結(jié)

以上所述是小編給大家介紹的JavaScript實現(xiàn)精美個性導(dǎo)航欄筋斗云效果,希望對大家有所幫助!

相關(guān)文章

  • js使用for循環(huán)與innerHTML獲取選中tr下td值

    js使用for循環(huán)與innerHTML獲取選中tr下td值

    這篇文章主要與大家分享了js使用for循環(huán)與innerHTML獲取選中tr下td值的方法,很簡單,但很實用,有需要的朋友可以參考下
    2014-09-09
  • 判斷javascript的數(shù)據(jù)類型(示例代碼)

    判斷javascript的數(shù)據(jù)類型(示例代碼)

    這篇文章主要是對判斷javascript的數(shù)據(jù)類型(示例代碼)進行了詳細的介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • js canvas實現(xiàn)擦除效果示例代碼

    js canvas實現(xiàn)擦除效果示例代碼

    擦除效果在我們?nèi)粘i_發(fā)中也是時有見到的,通過擦除效果大大加強了與用戶的交互性,所以下面這篇文章主要給大家介紹了利用js和canvas實現(xiàn)擦除效果的相關(guān)資料,文中給出了詳細的介紹和示例代碼,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-04-04
  • JavaScript使用Math.random()生成簡單的驗證碼

    JavaScript使用Math.random()生成簡單的驗證碼

    今天小編就為大家分享一篇關(guān)于JavaScript使用Math.random()生成簡單的驗證碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • JS實現(xiàn)公告上線滾動效果

    JS實現(xiàn)公告上線滾動效果

    這篇文章主要為大家詳細介紹了JS實現(xiàn)公告上線滾動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Javascript驗證用戶輸入URL地址是否為空及格式是否正確

    Javascript驗證用戶輸入URL地址是否為空及格式是否正確

    這篇文章主要介紹了Javascript驗證用戶輸入URL地址是否為空及格式是否正確,很實用,需要的朋友可以參考下
    2014-10-10
  • JS數(shù)組降維的實現(xiàn)Array.prototype.concat.apply([], arr)

    JS數(shù)組降維的實現(xiàn)Array.prototype.concat.apply([], arr)

    這篇文章主要介紹了JS數(shù)組降維的實現(xiàn)Array.prototype.concat.apply([], arr),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 原生javascript+css3編寫的3D魔方動畫旋扭特效

    原生javascript+css3編寫的3D魔方動畫旋扭特效

    這篇文章主要介紹了原生javascript+css3編寫的3D魔方動畫旋扭特效的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • javascript設(shè)計模式之module(模塊)模式

    javascript設(shè)計模式之module(模塊)模式

    這篇文章主要為大家詳細介紹了javascript設(shè)計模式之module(模塊)模式 ,感興趣的小伙伴們可以參考一下
    2016-08-08
  • layui表單驗證select下拉框?qū)崿F(xiàn)驗證的方法

    layui表單驗證select下拉框?qū)崿F(xiàn)驗證的方法

    今天小編就為大家分享一篇layui表單驗證select下拉框?qū)崿F(xiàn)驗證的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09

最新評論