中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript實現精美個性導航欄筋斗云效果

發布時間:2020-09-09 15:47:38 來源:腳本之家 閱讀:225 作者:Dragonir 欄目:web開發

實現效果:

  實現效果如下圖所示

JavaScript實現精美個性導航欄筋斗云效果

實現原理:

什么是筋斗云效果:

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

實現思路:

•鼠標經過的時候,利用offsetLeft獲得當前盒子距離左側的距離,把這個值賦給緩動動畫的end值。
•當點擊的時候記住當前的offsetLeft值,當鼠標經過的時候把之前點擊的offsetLeft給現在經過時候的值。

實現代碼:

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

<!DOCTYPE html>
<html>
<head>
  <title>導航欄筋斗云效果</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(){
    // 鼠標放在哪個li上面,span對應一道到哪里,移開后回到原位置
    var liArr = document.getElementsByTagName("li");
    var liWidth = liArr[0].offsetWidth;
    var span = document.getElementsByTagName("span")[0];
    // 計數器
    var cnt = 0;
    // for循環綁定事件
    for(var i=0; i<liArr.length; i++){
      // 自定義屬性,然后綁定index屬性為索引值
      liArr[i].index = i;
      // 鼠標進入事件
      liArr[i].onmouseover = function(){
        // 然span運動到該li的索引值位置
        animate(span, this.index*liWidth);
      }
      // 鼠標移開
      liArr[i].onmouseout = function(){
        // span運動到原位置
        animate(span, cnt*liWidth);
      }
      // 點擊事件
      liArr[i].onclick = function(){
        // 計數器記錄當前標簽索引值
        cnt = this.index;
        animate(span, cnt*liWidth);
      }
    }
    // 緩動動畫封裝
    function animate(element, target){
      // 清除間歇調用
      clearInterval(element.timer);
      // 設置超時調用
      element.timer = setInterval(function(){
        // 設置步數
        var step = (target - element.offsetLeft)/10;
        // 調整步數
        step = step > 0 ? Math.ceil(step) : Math.floor(step);
        // 設置樣式
        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> 

總結

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沛县| 阿尔山市| 苍溪县| 沙雅县| 浠水县| 客服| 农安县| 乐东| 天峻县| 多伦县| 盐城市| 舟山市| 镇江市| 格尔木市| 嘉鱼县| 五家渠市| 漯河市| 南开区| 金堂县| 疏勒县| 海宁市| 攀枝花市| 浮山县| 依兰县| 湾仔区| 承德县| 怀集县| 清水河县| 伊金霍洛旗| 自贡市| 玉屏| 道孚县| 平遥县| 南城县| 平原县| 车致| 海淀区| 西盟| 项城市| 东海县| 格尔木市|