码迷,mamicode.com
首页 > 编程语言 > 详细

Javascript实现页面滚动时导航智能定位

时间:2018-03-23 13:06:47      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:ber   offset   问题   位置   on()   实现   ext   wrap   gpo   

 

遇到的问题:

在做官网的时候,需要滚动定位的区块的图片不确定,无法确定用户浏览区域对应的模块导航

之前的解决方案是:

通过定位滚动条的位置来判断用户浏览区域对应的模块导航,这种方法的弊端是,区块的高度不确定时就无法计算滚动条的位置来判断;

优化方案:

页面中会有多个模块,每个模块对应一个导航,当页面滚动到某个模块时,对应的模块导航需要加上一个类用于区分当前用户所浏览区域。

以下是DEMO

<!-- html -->
<div class="container"> <div class="wrapper"> <div class="section" id="section1">section1</div> <div class="section" id="section2">section2</div> <div class="section" id="section3">section3</div> <div class="section" id="section4">section4</div> <div class="section" id="section5">section5</div> </div> <nav> <a href="#section1" rel="external nofollow" class="current">section1</a> <a href="#section2" rel="external nofollow" >section2</a> <a href="#section3" rel="external nofollow" >section3</a> <a href="#section4" rel="external nofollow" >section4</a> <a href="#section5" rel="external nofollow" >section5</a> </nav> </div>
 
<script>
<!-- 页面滚动时导航定位 -->
 var $navs = $(‘nav a‘), // 导航
  $sections = $(‘.section‘),  // 模块
  $window = $(window),
  navLength = $navs.length - 1;
   
  $window.on(‘scroll‘, function() {
  var scrollTop = $window.scrollTop(),
    len = navLength;
    for (; len > -1; len--) {
      var that = $sections.eq(len);
      if (scrollTop >= that.offset().top) {
         $navs.removeClass(‘current‘).eq(len).addClass(‘current‘);
         break;
      }
    }
  });
<!-- 点击导航定位页面 -->
  $navs.on(‘click‘, function(e) {
    e.preventDefault();
    $(‘html, body‘).animate({
    ‘scrollTop‘: $($(this).attr(‘href‘)).offset().top
    }, 400);
  });
</script>

  

write by  tuantuan

Javascript实现页面滚动时导航智能定位

标签:ber   offset   问题   位置   on()   实现   ext   wrap   gpo   

原文地址:https://www.cnblogs.com/widgetbox/p/8629481.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!