想作一個導航跟隨,可是代碼都要下載,本身簡單些了一個,css都放html裏面了,因此也不用下載直接新建html,而後粘貼,點開就是導航跟隨效果css
效果如圖html
<!DOCTYPE html> <html> <head> <title>導航跟隨</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script src="http://www.w3school.com.cn/jquery/jquery-1.11.1.min.js"></script> </head> <style> #nav { display: -webkit-box; display: -ms-flexbox; display: -webkit-flex; display: flex; line-height: 30px; font-size: 14px; width: 100%; position: fixed; top: 0px; left: 0px; z-index: 100; border-bottom: 1px solid #e5e5e5; border-top: 1px solid #e5e5e5; min-height: 44px; background: #000; } #nav a { display: block; position: relative; width: 25%; line-height: 44px; text-align: center; color: #fff; } #nav a.active { color: #fff; background: red; } #main { padding-top: 44px; } </style> <script> $(window).load(function () { $('html, body').animate({ scrollTop: 0 }, 200); var nav = $("#nav"); var mainPage = $(".mainPage"); var mainTopArr = new Array(); for (var i = 0; i < mainPage.length; i++) { var top = mainPage.eq(i).offset().top; mainTopArr.push(top); } $(window).scroll(function () { var scrollTop = $(this).scrollTop(); var k; for (var i = 0; i < mainTopArr.length; i++) { if (scrollTop + 144 >= mainTopArr[i]) { k = i; } } nav.find("a").eq(k).addClass("active").siblings().removeClass("active"); }); nav.find("a[href^='#']").click(function (e) { e.preventDefault(); $('html, body').animate({ scrollTop: $(this.hash).offset().top - 144 }, 200); }); }); </script> <body> <div id="nav"> <a href="#imgdetails" class="active">商品</a> <a href="#specifications">規格</a> <a href="#reviews">評價</a> <a href="#description">詳情</a> </div> <div id="main"> <div class="mainPage" id="imgdetails"style="height:500px">我是第一塊的內容</div> <div class="mainPage" id="specifications" style="height:500px">我是第二塊的內容</div> <div class="mainPage" id="reviews" style="height:500px">我是全部評論啦,來看評論</div> <div class="mainPage" id="description" style="height:500px">我是介紹,來看介紹</div> </body> </html>
原本是想用document.ready,可是應用到實際中有頁面包含了不少絕對定位的元素,定位並不許確。jquery