本文实例为大家分享了js实现滑动导航栏效果的具体代码,供大家参考,具体内容如下
<!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){ //箭头符号的变化
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){ //滑动栏点击样式
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){ //下拉点击样式
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){ //滑动栏移动效果
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>
导航栏可滑动
下拉点击会相应的改变导航栏
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# 滑动
# 导航栏
# JS中用三种方式实现导航菜单中的二级下拉菜单
# JS实现选中当前菜单后高亮显示的导航条效果
# 一个js控制的导航菜单实例代码
# CSS3+Js实现响应式导航条
# JS 实现导航栏悬停效果
# js实现移动端导航点击自动滑动效果
# JavaScript实现鼠标点击导航栏变色特效
# js实现无限级树形导航列表效果代码
# js实现的常用的左侧导航效果
# 原生js实现波浪导航效果
# 大家分享
# 具体内容
# 大家多多
# scroll
# px
# container
# left
# float
# div
# height
# navScroll
# padding
# margin
# position
# overflow
# relative
# line
# top
# absolute
# drop_down
相关文章:
如何自定义建站之星网站的导航菜单样式?
建站之星在线客服如何快速接入解答?
C#如何序列化对象为XML XmlSerializer用法
建站之星免费版是否永久可用?
PHP正则匹配日期和时间(时间戳转换)的实例代码
建站之星价格显示格式升级,你的预算足够吗?
大连 网站制作,大连天途有线官网?
高端企业智能建站程序:SEO优化与响应式模板定制开发
广东企业建站网站优化与SEO营销核心策略指南
开心动漫网站制作软件下载,十分开心动画为何停播?
公司网站的制作公司,企业网站制作基本流程有哪些?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
建站之星微信建站一键生成小程序+多端营销系统
如何配置支付宝与微信支付功能?
如何在阿里云香港服务器快速搭建网站?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
如何基于云服务器快速搭建网站及云盘系统?
如何用搬瓦工VPS快速搭建个人网站?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
如何在景安服务器上快速搭建个人网站?
制作网站的软件免费下载,免费制作app哪个平台好?
广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?
建站168自助建站系统:快速模板定制与SEO优化指南
如何在七牛云存储上搭建网站并设置自定义域名?
如何确保西部建站助手FTP传输的安全性?
如何零基础在云服务器搭建WordPress站点?
ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?
济南企业网站制作公司,济南社保单位网上缴费步骤?
如何在Windows 2008云服务器安全搭建网站?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
如何通过FTP服务器快速搭建网站?
怎么将XML数据可视化 D3.js加载XML
制作网站外包平台,自动化接单网站有哪些?
建站之星ASP如何实现CMS高效搭建与安全管理?
建设网站制作价格,怎样建立自己的公司网站?
如何设置并定期更换建站之星安全管理员密码?
如何快速辨别茅台真假?关键步骤解析
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
临沂网站制作企业,临沂第三中学官方网站?
制作旅游网站html,怎样注册旅游网站?
教程网站设计制作软件,怎么创建自己的一个网站?
建站主机选虚拟主机还是云服务器更好?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
南平网站制作公司,2025年南平市事业单位报名时间?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
*请认真填写需求信息,我们会在24小时内与您取得联系。