JQ滑動導航菜單的實現


前言:不多說直接看效果!!!
這樣的菜單我們在一般的網站上見到的也比較多,有比較好的用戶體驗!
 
原理:這個很重要,任何的特效只要原理搞明白了,實現起來都是很容易的!這個特效的原理很簡單,菜單的樣式我們都很容易實現就是一些CSS而已!
中間那個滑塊其實就是一個定位為: absolute 的元素,每當鼠標放到一個A元素上的時候用JQ獲取到當前A元素的位置和寬度,再用JQ的animate方法,以動畫的形式給元素即可!
當然你在這里也可以也一些其它的動畫

1、DOM結構
<div class="nav-wrapper">
        <div class="container">
            <ul id="nav-list">
                <li class="nav-item"><a href="http://www.lanrentuku.com/" class="active" target="_blank">網站首頁</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">網上商城</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">智能管家</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">技術支持</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">應用案例</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">關於我們</a></li>
                <li class="nav-item"><a href="http://www.lanrentuku.com/" target="_blank">懶人圖庫</a></li>
            </ul>
            <div class="animate-block"></div>
        </div>
    </div>

  

2、對應的CSS
 1 *{margin: 0;padding: 0;}
 2         body{ font-family:"Microsoft YaHei";}
 3         .container {
 4             width: 1200px;
 5             margin: 30px auto;
 6             position: relative;
 7         }
 8         li {
 9             list-style: none;
10         }
11         .nav-wrapper {
12             background-color: #0191d7;
13             height: 50px;
14         }
15         #nav-list {
16             position: relative;
17             z-index: 1;
18         }
19         #nav-list .nav-item {
20             float:left;
21             height: 50px;
22         }
23         #nav-list li a{
24             display: block;
25             padding: 0 50px;
26             height: 50px;
27             font-size: 16px;
28             line-height: 50px;
29             color: #fff;
30             text-decoration: none;
31         }
32         .animate-block {
33             position: absolute;
34             height: 50px;
35             background-color: #2B6B8A;
36             left: 0;
37             top:0;
38             z-index: 0;
39         }
40         .active {
41             box-shadow: 0 0 2px rgba(0,0,0,.1);
42         }
View Code

 

3、JQ代碼
$(function () {
        var $active = $(".active"); //當前選中的菜單
        var $active_w = $active.innerWidth();
        var $active_l = $active.position().left;
        var $animate_block = $(".animate-block");
 
        //設置滑塊初始位置
        $(".animate-block").css({width:$active_w,left:$active_l});
 
        //a事件
        $("#nav-list>li").hover(function () {
            var index = $(this).index();
            var $a_cur = $("#nav-list a").eq(index);//得到當前元素
            var width = $a_cur.innerWidth();
            var left = $a_cur.position().left;
            $(".animate-block").stop().animate({width:width,left:left});
        },function () {
            $(".animate-block").stop().animate({width:$active_w,left:$active_l});
        });
    });
View Code

 

參考資料:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM