上下滚动将类添加到div

时间:2019-04-26 14:12:15

标签: javascript jquery html css

如您所见,我有许多垂直排列的点!在向下滚动时,它起作用了,当向下滚动一个点时,它得到了一个改变球样式的类,我希望在向上滚动时发生完全相同的操作,但它不起作用!请任何输入表示赞赏!

这里有code pen供您参考!

在html,css和javascript下面:

var activeMilestone = function() {
  var milestoneBalls = $('.dot');
  milestoneBalls[0].classList.add("active");
  window.onscroll = function() {
    milestoneBalls.each(function(i, v) {
      var thisBall = $(this);
      var nextBall = milestoneBalls[i + 1];
      var prevBall = milestoneBalls[i - 1];
      var thisPositionTop = thisBall.offset().top + ($(this).parent().height() / 3);
      var winScroll = window.scrollY;
      if (thisPositionTop <= winScroll) {
        nextBall.classList.add("active");
        thisBall.addClass("inactive");
      }
      if (thisPositionTop >= winScroll) {
        //this.classList.add("inactive_ball");
      }
    });
  }
}
$(document).ready(activeMilestone);
.wrapper {
  height: 1000px;
  background-color: wheat;
}

.info_wrapper {
  margin-top: 70px;
}

.container {
  height: 50%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}

.dot {
  width: 30px;
  height: 30px;
  border-radius: 20px;
  background-color: maroon;
  border: solid 4px green;
}

.active {
  border: solid 4px yellow;
  background-color: red;
}

.inactive {
  background-color: maroon;
  border: solid 4px green;
}

.text {}

.header {
  width: 100%;
  height: 50px;
  background-color: lightblue;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="wrapper">
  <div class="header"></div>
  <div class="container">
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>

  </div>
</div>

2 个答案:

答案 0 :(得分:1)

因此,此逻辑执行与您已经执行的相同的操作。使用的附加逻辑,如果该元素不应该前进,并且我们不是第一个元素,则检查是否应激活前一个球。如果是这样,我们将其激活。

var activeMilestone = function() {
  var milestoneBalls = $('.dot');
  
  milestoneBalls.eq(0).addClass('active');
  
  window.addEventListener('scroll', function() {
    var activeBall = milestoneBalls.filter('.active');
    var activeBallIndex = milestoneBalls.index( activeBall );
    var activeBallPositionTop = activeBall.offset().top + (activeBall.parent().height() / 3);
    
    if (activeBallPositionTop <= window.scrollY) {
      activeBall.removeClass('active');
      milestoneBalls.eq( activeBallIndex + 1).addClass('active');
    } else if ( activeBallIndex ) {
      var previousBall = milestoneBalls.eq( activeBallIndex - 1 );
      var previousBallPositionTop = previousBall.offset().top + (previousBall.parent().height() / 3);
      
      if (previousBallPositionTop > window.scrollY) {
        activeBall.removeClass('active');
        previousBall.addClass('active');
      }
    }
  });
}
$(document).ready(activeMilestone);
.wrapper {
  height: 1000px;
  background-color: wheat;
}

.info_wrapper {
  margin-top: 70px;
}

.container {
  height: 50%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}

.dot {
  width: 30px;
  height: 30px;
  border-radius: 20px;
  background-color: maroon;
  border: solid 4px green;
}

.active {
  border: solid 4px yellow;
  background-color: red;
}

.inactive {
  background-color: maroon;
  border: solid 4px green;
}

.text {}

.header {
  width: 100%;
  height: 50px;
  background-color: lightblue;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="wrapper">
  <div class="header"></div>
  <div class="container">
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot "></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>
    <div class="info_wrapper">
      <div class="text"></div>
      <div class="dot"></div>
    </div>

  </div>
</div>

答案 1 :(得分:0)

您可以在jQuery中使用 onwheel

$(window).on('wheel',function(e) {
  var mov = e.originalEvent.deltaY;
  if(mov > 0) {
    alert("up");
  }else {
    alert("down");
  }
});

这将解决有关滚动方向检测的问题。