JavaScript實(shí)現(xiàn)滑動(dòng)導(dǎo)航欄效果
本文實(shí)例為大家分享了js實(shí)現(xiàn)滑動(dòng)導(dǎo)航欄效果的具體代碼,供大家參考,具體內(nèi)容如下
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1.0 ,user-scalable=no">
<script src="node_modules/jquery/jquery.js"></script>
<style>
*{
margin: 0;
padding: 0;
}
.navScroll{
position: relative;
}
#overflow{
width: 100%;
height: 30px;
overflow-x: scroll;
}
#overflow .container{
height: 30px;
}
#overflow .container div{
float: left;
width: 100px;
height: 30px;
line-height: 30px;
text-align: center;
}
#overflow::-webkit-scrollbar {
display: none;
-webkit-overflow-scrolling: touch;
}
.navScroll .drop_down{
position: absolute;
top: 0;
right: 0;
width: 50px;
height: 30px;
}
.navScroll .drop_down img{
width: 100%;
height: 100%;
}
.tabUl.clearFix{
display: none;
width: 100%;
list-style: none;
z-index: 10;
background: rgba(0,0,0,.1);
}
.tabUl li{
float: left;
width: 6.25rem;
height: 2.65625rem;
line-height: 2.65625rem;;
text-align: center;
}
.clearFix{
content: "";
display: table;
clear: both;
}
div, ul{
color: #89CFE8;
}
#overflow .container div.lastWidth{
width: 50px;
}
.red{
color: #FF9933;
}
</style>
</head>
<body>
<div class="navScroll">
<div id="overflow">
<div class="container">
<div class="tabItem red">
item1
</div>
<div class="tabItem">
item2
</div>
<div class="tabItem">
item3
</div>
<div class="tabItem">
item4
</div>
<div class="tabItem">
item5
</div>
<div class="tabItem">
item6
</div>
<div class="tabItem">
item7
</div>
<div class="tabItem">
item8
</div>
<div class="tabItem">
item9
</div>
<div class="tabItem">
item10
</div>
<div class="tabItem">
item11
</div>
<div class="lastWidth"></div>
</div>
</div>
<div class="drop_down">
<img src="img/icon_events_fold.png" drop="down" alt="" />
</div>
<ul class="tabUl clearFix">
<li class="red">item1</li>
<li >item2</li>
<li >item3</li>
<li >item4</li>
<li >item5</li>
<li >item6</li>
<li >item7</li>
<li >item8</li>
<li >item9</li>
<li >item10</li>
<li >item11</li>
</ul>
</div>
</body>
<script>
var width = 0;
$('#overflow .container div').each(function () {
width += $(this).outerWidth(true);
});
$('#overflow .container').css('width', width + "px");
var flag = true;
$(".drop_down img").click(function(e){ //箭頭符號(hào)的變化
if(flag){
$(".drop_down img").attr("src","img/icon_events_unfold.png");
$(".tabUl").css("display","block")
flag = false;
}else{
$(".drop_down img").attr("src","img/icon_events_fold.png");
$(".tabUl").css("display","none")
flag = true;
}
});
var ulHeight= Math.ceil(($(".tabUl li").length-1)/6)*2.65625 +"rem";
$(".navScroll .tabUl").css("height",ulHeight)
$(".navScroll").on("click",".tabItem",function(e,index){ //滑動(dòng)欄點(diǎn)擊樣式
var $this=$(this);
$(".tabItem").css({"color": "#89CFE8"})
$($this).css({"color": "#FF9933"});
var items = $($this)[0];
var ulIndx;
$(".tabItem").each(function(i,n){
if(n==items){
ulIndx = i;
}
})
$(".tabUl li").css({"color": "#89CFE8"});
var ulItems = $(".tabUl li")[ulIndx];
$(ulItems).css({"color": "#FF9933"});
moveNav(ulIndx);
})
$(".navScroll").on("click","li",function(e,index){ //下拉點(diǎn)擊樣式
var $this=$(this);
$("li").css({"color": "#89CFE8"})
$($this).css({"color": "#FF9933"});
var items = $($this)[0];
var ulIndx;
$("li").each(function(i,n){
if(n==items){
ulIndx = i;
}
})
$(".tabItem").css({"color": "#89CFE8"});
var ulItems = $(".tabItem")[ulIndx];
$(ulItems).css({"color": "#FF9933"});
$(".drop_down img").attr("src","img/icon_events_fold.png");
$(".tabUl").css("display","none")
flag = true;
moveNav(ulIndx);
})
function moveNav(index){ //滑動(dòng)欄移動(dòng)效果
var allImg = $(".navScroll").find(".tabItem");
var navImgWidth = allImg.width();
var lastWidth = $(".container .lastWidth").width();
var windowWidth = $(window).width();
var navBox = $("#overflow");
if(navImgWidth*(index+1) >=windowWidth-navImgWidth){
if(navImgWidth*(index+1)<navImgWidth*(allImg.length-1)+lastWidth-windowWidth){
navBox.animate({scrollLeft:navImgWidth*(index+1)},500);
}else{
navBox.animate({scrollLeft:navImgWidth*(allImg.length)+lastWidth-windowWidth},500);
}
}else{
navBox.animate({scrollLeft:'0px'},1000);
}
}
</script>
</html>
導(dǎo)航欄可滑動(dòng)

下拉點(diǎn)擊會(huì)相應(yīng)的改變導(dǎo)航欄

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JS中用三種方式實(shí)現(xiàn)導(dǎo)航菜單中的二級(jí)下拉菜單
- JS實(shí)現(xiàn)選中當(dāng)前菜單后高亮顯示的導(dǎo)航條效果
- 一個(gè)js控制的導(dǎo)航菜單實(shí)例代碼
- CSS3+Js實(shí)現(xiàn)響應(yīng)式導(dǎo)航條
- JS 實(shí)現(xiàn)導(dǎo)航欄懸停效果
- js實(shí)現(xiàn)移動(dòng)端導(dǎo)航點(diǎn)擊自動(dòng)滑動(dòng)效果
- JavaScript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊導(dǎo)航欄變色特效
- js實(shí)現(xiàn)無(wú)限級(jí)樹(shù)形導(dǎo)航列表效果代碼
- js實(shí)現(xiàn)的常用的左側(cè)導(dǎo)航效果
- 原生js實(shí)現(xiàn)波浪導(dǎo)航效果
相關(guān)文章
JS+DIV+CSS實(shí)現(xiàn)的經(jīng)典標(biāo)簽切換效果代碼
這篇文章主要介紹了JS+DIV+CSS實(shí)現(xiàn)的經(jīng)典標(biāo)簽切換效果代碼,涉及JavaScript基于鼠標(biāo)事件針對(duì)頁(yè)面元素動(dòng)態(tài)變換的實(shí)現(xiàn)技巧,頁(yè)面美觀實(shí)用,需要的朋友可以參考下2015-09-09
input file的默認(rèn)value清空與賦值方法
出于安全性考慮,JS是不能直接設(shè)置File的value值的,下面是我總結(jié)出來(lái)的方法2010-09-09
javascript時(shí)間函數(shù)基礎(chǔ)介紹
這篇文章主要介紹了javascript中提供了Date對(duì)象來(lái)進(jìn)行時(shí)間和日期的計(jì)算,這里簡(jiǎn)單的介紹下, 方便需要的朋友2013-03-03
js和jquery實(shí)現(xiàn)tab狀態(tài)欄切換效果
這篇文章主要為大家詳細(xì)介紹了js和jquery實(shí)現(xiàn)tab狀態(tài)欄切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
JavaScript XML實(shí)現(xiàn)兩級(jí)級(jí)聯(lián)下拉列表
用xml作為存儲(chǔ)容器,不用數(shù)據(jù)庫(kù),速度和效率高些。2008-11-11
JS動(dòng)態(tài)修改iframe內(nèi)嵌網(wǎng)頁(yè)地址的方法
這篇文章主要介紹了JS動(dòng)態(tài)修改iframe內(nèi)嵌網(wǎng)頁(yè)地址的方法,涉及javascript動(dòng)態(tài)修改iframe中src屬性的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04
javascript currying返回函數(shù)的函數(shù)
currying函數(shù)是一種返回函數(shù)的函數(shù),是閉包最偉大的應(yīng)用之一。有關(guān)閉包更詳細(xì)的定義可參見(jiàn)這里與這里。如下currying函數(shù)的一種定義。2009-11-11
使用js原生實(shí)現(xiàn)年份輪播選擇效果實(shí)例
這篇文章主要給大家介紹了關(guān)于如何使用js原生實(shí)現(xiàn)年份輪播選擇效果的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
js判斷在哪個(gè)瀏覽器打開(kāi)項(xiàng)目的方法
這篇文章主要介紹了js判斷在哪個(gè)瀏覽器打開(kāi)項(xiàng)目的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01

