全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript实现滑动导航栏效果

本文实例为大家分享了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 


相关文章: 如何用低价快速搭建高质量网站?  武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?  建站之星如何实现PC+手机+微信网站五合一建站?  建站之星后台管理:高效配置与模板优化提升用户体验  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  如何实现建站之星域名转发设置?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  建站168自助建站系统:快速模板定制与SEO优化指南  建站主机与虚拟主机有何区别?如何选择最优方案?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何快速选择适合个人网站的云服务器配置?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  深圳网站制作培训,深圳哪些招聘网站比较好?  再谈Python中的字符串与字符编码(推荐)  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  建站VPS配置与SEO优化指南:关键词排名提升策略  制作国外网站的软件,国外有哪些比较优质的网站推荐?  如何用搬瓦工VPS快速搭建个人网站?  如何批量查询域名的建站时间记录?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  Python文件管理规范_工程实践说明【指导】  建站之星图片链接生成指南:自助建站与智能设计教程  如何配置支付宝与微信支付功能?  建站之星上传入口如何快速找到?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  孙琪峥织梦建站教程如何优化数据库安全?  如何在阿里云部署织梦网站?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  高端建站如何打造兼具美学与转化的品牌官网?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  如何快速搭建自助建站会员专属系统?  制作网站的基本流程,设计网站的软件是什么?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  如何通过云梦建站系统实现SEO快速优化?  制作网站的模板软件,网站怎么建设?  中山网站制作网页,中山新生登记系统登记流程?  如何挑选最适合建站的高性能VPS主机?  建站之星后台密码遗忘或太弱?如何重置与强化?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  小型网站制作HTML,*游戏网站怎么搭建?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  如何设置并定期更换建站之星安全管理员密码?  建站之星如何防范黑客攻击与数据泄露?  Thinkphp 中 distinct 的用法解析  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  建站之星如何通过成品分离优化网站效率? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。