javascript – 在向下滚动时淡入,在向上滚动时淡出 – 基于窗口中的元素位置

当它们在窗口中完全可见时,我试图让一系列元素在向下滚动时淡入.如果我继续向下滚动,我不希望它们淡出,但如果我向上滚动,我确实希望它们淡出.

这是我发现的最接近的jsfiddle.
http://jsfiddle.net/tcloninger/e5qaD/

$(document).ready(function() {

/* Every time the window is scrolled ... */
$(window).scroll( function(){

    /* Check the location of each desired element */
    $('.hideme').each( function(i){

        var bottom_of_object = $(this).position().top + $(this).outerHeight();
        var bottom_of_window = $(window).scrollTop() + $(window).height();

        /* If the object is completely visible in the window, fade it it */
        if( bottom_of_window > bottom_of_object ){

            $(this).animate({'opacity':'1'},500);

        }    
    }); 
}); 
});

它完全按照我想要的向下滚动,但如果我向上滚动它们,我也希望元素淡出.

我试了这个没有运气.

            if( bottom_of_window > bottom_of_object ){

                $(this).animate({'opacity':'1'},500);  

            } else {

               $(this).animate({'opacity':'0'},500); }

非常感谢您花时间看这个.

解决方法:

你的尝试不起作用的原因是因为两个动画(淡入和淡出)相互作用.

在对象变得可见之前,它仍然是不可见的,因此淡出的动画将会运行.然后,当相同的对象变得可见时,一小段时间后,淡入动画将尝试运行,但淡出仍然在运行.所以他们会相互对抗,你什么也看不见.

最终,对象将变得可见(大部分时间),但这需要一段时间.如果您使用滚动条按钮上的箭头按钮向下滚动,则动画会有效,因为您可以使用更大的增量滚动,从而创建更少的滚动事件.

足够的解释,解决方案(JS,CSS,HTML):

$(window).on("load",function() {
  $(window).scroll(function() {
    var windowBottom = $(this).scrollTop() + $(this).innerHeight();
    $(".fade").each(function() {
      /* Check the location of each desired element */
      var objectBottom = $(this).offset().top + $(this).outerHeight();
      
      /* If the element is completely within bounds of the window, fade it in */
      if (objectBottom < windowBottom) { //object comes into view (scrolling down)
        if ($(this).css("opacity")==0) {$(this).fadeto(500,1);}
      } else { //object goes out of view (scrolling up)
        if ($(this).css("opacity")==1) {$(this).fadeto(500,0);}
      }
    });
  }).scroll(); //invoke scroll-handler on page-load
});
.fade {
  margin: 50px;
  padding: 50px;
  background-color: lightgreen;
  opacity: 1;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>

<div>
  <div class="fade">Fade In 01</div>
  <div class="fade">Fade In 02</div>
  <div class="fade">Fade In 03</div>
  <div class="fade">Fade In 04</div>
  <div class="fade">Fade In 05</div>
  <div class="fade">Fade In 06</div>
  <div class="fade">Fade In 07</div>
  <div class="fade">Fade In 08</div>
  <div class="fade">Fade In 09</div>
  <div class="fade">Fade In 10</div>
</div>

(小提琴:http://jsfiddle.net/eLwex993/2/)

>我将淡化代码行包装在if子句中:if($(this).css(“opacity”)== 0){…}.这样可以确保仅在不透明度为0时对象才会淡入.淡出也是如此.这可以防止淡入和淡出相互作用,因为现在只有一个在对象上同时运行.
>我将.animate()更改为.fadeto().这是jQuery的不透明度的专用功能,写入时间要短得多,而且可能比动画更轻.
>我将.position()更改为.offset().这总是相对于身体计算,而位置是相对于父亲.对于你的情况,我认为偏移是要走的路.
>我将$(window).height()更改为$(window).innerHeight().根据我的经验,后者更可靠.
>直接在scroll-handler之后,我在页面加载时使用$(window).scroll();调用该处理程序一次.现在,您可以在页面上为.fade类提供所有需要的对象,并且在页面加载时应该不可见的对象将立即淡出.
>我从HTML和CSS中删除了#container,因为(至少对于这个答案)没有必要. (我想也许你需要高度:2000px,因为你使用了.position()而不是.offset(),否则我不知道.当然不要把它留在你的代码中.)

UPDATE

如果希望不透明度值不是0和1,请使用以下代码

$(window).on("load",function() {
  function fade(pageLoad) {
    var windowBottom = $(window).scrollTop() + $(window).innerHeight();
    var min = 0.3;
    var max = 0.7;
    var threshold = 0.01;
    
    $(".fade").each(function() {
      /* Check the location of each desired element */
      var objectBottom = $(this).offset().top + $(this).outerHeight();
      
      /* If the element is completely within bounds of the window, fade it in */
      if (objectBottom < windowBottom) { //object comes into view (scrolling down)
        if ($(this).css("opacity")<=min+threshold || pageLoad) {$(this).fadeto(500,max);}
      } else { //object goes out of view (scrolling up)
        if ($(this).css("opacity")>=max-threshold || pageLoad) {$(this).fadeto(500,min);}
      }
    });
  } fade(true); //fade elements on page-load
  $(window).scroll(function(){fade(false);}); //fade elements on scroll
});
.fade {
  margin: 50px;
  padding: 50px;
  background-color: lightgreen;
  opacity: 1;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>

<div>
  <div class="fade">Fade In 01</div>
  <div class="fade">Fade In 02</div>
  <div class="fade">Fade In 03</div>
  <div class="fade">Fade In 04</div>
  <div class="fade">Fade In 05</div>
  <div class="fade">Fade In 06</div>
  <div class="fade">Fade In 07</div>
  <div class="fade">Fade In 08</div>
  <div class="fade">Fade In 09</div>
  <div class="fade">Fade In 10</div>
</div>

(小提琴:http://jsfiddle.net/eLwex993/3/)

>我在if子句中添加一个阈值,请参阅下面的说明.
>我在函数开始时为阈值和最小/最大值创建了变量.在函数的其余部分中,引用了这些变量.这样,如果您想再次更改值,则只需在一个位置执行此操作.
>我还添加了|| pageLoad到if子句.这是确保所有对象在页面加载时淡化到正确的不透明度所必需的. pageLoad是一个布尔值,在调用fade()时作为参数发送.
我必须将淡入淡出代码放在额外的函数fade(){…}中,以便能够在调用scroll-handler时沿pageLoad boolean发送.
我没有看到任何其他方法,如果有其他人这样做,请发表评论.

说明:
your fiddle中的代码不起作用的原因是因为实际不透明度值总是与您设置的值略有偏差.因此,如果将不透明度设置为0.3,则实际值(在本例中)为0.300000011920929.这只是你必须通过追踪和错误一路学习的小错误之一.这就是为什么这个if子句不起作用的原因:if($(this).css(“opacity”)== 0.3){…}.

添加一个阈值,将这个差异考虑在内:== 0.3变为< = 0.31.
(我已将阈值设置为0.01,当然可以改变,只要实际不透明度将落在设定值和此阈值之间.)

现在,运算符从==更改为< =和> =.

更新2:

如果要根据可见百分比淡化元素,请使用以下代码

$(window).on("load",function() {
  function fade(pageLoad) {
    var windowTop=$(window).scrollTop(), windowBottom=windowTop+$(window).innerHeight();
    var min=0.3, max=0.7, threshold=0.01;
    
    $(".fade").each(function() {
      /* Check the location of each desired element */
      var objectHeight=$(this).outerHeight(), objectTop=$(this).offset().top, objectBottom=$(this).offset().top+objectHeight;
      
      /* Fade element in/out based on its visible percentage */
      if (objectTop < windowTop) {
        if (objectBottom > windowTop) {$(this).fadeto(0,min+((max-min)*((objectBottom-windowTop)/objectHeight)));}
        else if ($(this).css("opacity")>=min+threshold || pageLoad) {$(this).fadeto(0,min);}
      } else if (objectBottom > windowBottom) {
        if (objectTop < windowBottom) {$(this).fadeto(0,min+((max-min)*((windowBottom-objectTop)/objectHeight)));}
        else if ($(this).css("opacity")>=min+threshold || pageLoad) {$(this).fadeto(0,min);}
      } else if ($(this).css("opacity")<=max-threshold || pageLoad) {$(this).fadeto(0,max);}
    });
  } fade(true); //fade elements on page-load
  $(window).scroll(function(){fade(false);}); //fade elements on scroll
});
.fade {
  margin: 50px;
  padding: 50px;
  background-color: lightgreen;
  opacity: 1;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>

<div>
  <div class="fade">Fade In 01</div>
  <div class="fade">Fade In 02</div>
  <div class="fade">Fade In 03</div>
  <div class="fade">Fade In 04</div>
  <div class="fade">Fade In 05</div>
  <div class="fade">Fade In 06</div>
  <div class="fade">Fade In 07</div>
  <div class="fade">Fade In 08</div>
  <div class="fade">Fade In 09</div>
  <div class="fade">Fade In 10</div>
</div>

(小提琴:http://jsfiddle.net/eLwex993/5/)

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...