2017-12-27 3 views
0

sitepoint에서 무한 스크롤에 대한 코드를 보았습니다.이 코드를 독자적으로 적용하려고 시도했지만 아래로 스크롤하면 트리거되지 않지만 맨 위로 스크롤하면 작동합니다. 맨 아래로 스크롤 할 때 무한 스크롤이 작동하지 않는 이유는 무엇입니까?

https://codepen.io/SitePoint/pen/JGQPPa

그래서 나는 그것을 아래로 스크롤 할 수 있는지 그것을 조금 변경하고 내가 정상에 스크롤 경우에만 트리거 곳은 여전히 ​​같은 일을하고 있어요.

$(document).ready(function() { 
      var win = $(window); 
      var page = 1; 

      $.fn.scrollBottom = function() { 
       return $(document).height() - this.scrollTop() - this.height(); 
      }; 

      // Each time the user scrolls 
      win.scroll(function() { 
       // End of the document reached? 
       if ($(document).height() - win.height() === win.scrollBottom()) { 

        $.ajax({ 
         url: '/purchases?page='+page, 
         dataType: 'html', 
         success: function(html) { 
          $('#app_posts').append(html); 
          page = page + 1; 
          console.log(page); 
         } 
        }); 
       } 
      }); 
     }); 

이 코드를 스크롤 위쪽이 아닌 아래쪽 방향으로 트리거하는 방법은 무엇입니까?

답변

1

문서의 높이와 창 높이를 비교하고 있지만 스크롤하는 동안 변경되지는 않습니다. 그래서 코드가 효과가 없었습니다. 이런 식으로 뭔가를 시도 :

$(document).ready(function(){ 
 
\t $(window).scroll(function(){ 
 
\t \t if($(window).scrollTop() > ($(document).height() - $(window).height() - 10)){ 
 
\t \t \t // REACHED BOTTOM 
 
     // PUT YOUR CODE HERE 
 
     
 
     $('#posts').append(randomPost()); 
 
\t \t } 
 
\t }); 
 
}); 
 

 

 
function randomPost() { 
 
\t // Paragraphs that will appear in the post 
 
\t var paragraphs = [ 
 
\t \t '<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras vitae suscipit arcu. Praesent pretium orci neque, non egestas massa suscipit non. In urna ligula, pretium ac magna in, consectetur venenatis dui. Etiam id commodo neque, vel semper nunc. Vivamus porttitor condimentum pulvinar. Quisque et consequat mi. Suspendisse luctus, quam in dapibus venenatis, velit erat malesuada lacus, dapibus tincidunt neque ex vitae leo. Suspendisse fermentum sit amet urna eu dignissim. Curabitur vel nibh quis justo volutpat porttitor et tempus sem.</p>', 
 
\t \t '<p>In a luctus purus, in tempus mi. Integer vulputate tincidunt arcu quis aliquet. Maecenas sollicitudin nec nisi sit amet dictum. Curabitur sagittis nulla id sem vulputate, eget blandit nibh ullamcorper. Nam feugiat elementum pharetra. Vestibulum a purus eget mi mattis tincidunt a sed felis. Sed pretium dignissim elementum. Cras est arcu, posuere et justo in, vehicula rutrum elit. Phasellus dictum risus libero, non cursus neque faucibus a. Nunc dignissim at purus vitae condimentum. Curabitur in libero mi.</p>', 
 
\t \t '<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed at tristique nibh, sed congue ligula. Curabitur eu porttitor tellus. Aliquam eu mollis tortor. Donec tortor sapien, molestie eu turpis vel, ultrices pulvinar orci. Aenean sagittis sem sit amet viverra maximus. Morbi id enim ipsum. Curabitur luctus placerat erat ut volutpat. In quis eros mattis, rutrum neque ut, malesuada neque.</p>', 
 
\t \t '<p>Integer erat eros, vestibulum at tortor vitae, sollicitudin finibus est. Aliquam ornare, elit nec gravida sagittis, sapien nibh elementum felis, eu eleifend eros lectus non mi. Nulla vel nisl scelerisque, consectetur nibh vel, malesuada lacus. Nam lobortis accumsan nisl consequat dictum. Praesent eget lobortis lorem. Ut sed ultrices enim. Nam nec ultricies felis.</p>', 
 
\t \t '<p>Donec hendrerit dolor id auctor ullamcorper. Curabitur ut mauris dolor. Quisque vitae cursus eros, ac rutrum sem. Aenean in turpis turpis. Fusce sit amet libero id massa dictum fermentum at eget arcu. Vestibulum eget blandit urna. In eu tristique augue. Phasellus augue risus, porttitor vel arcu nec, tincidunt laoreet tellus. Nam ornare leo dapibus ipsum dictum interdum.</p>', 
 
\t \t '<p>Nulla molestie porttitor justo vitae pharetra. Proin non convallis lacus, eget malesuada metus. Duis aliquam eu massa molestie rhoncus. Vestibulum a malesuada nulla. Morbi at libero tempus, hendrerit quam vitae, auctor eros. Vivamus tincidunt enim a est tincidunt, sed fringilla erat placerat. Nulla cursus, eros sed posuere sagittis, dui est lobortis tellus, id dapibus dui sem eget enim. Vestibulum eleifend lacus velit, ut suscipit nisi bibendum at. Nulla facilisi. Aenean luctus tellus eget nisi vestibulum, eget interdum lectus efficitur.</p>', 
 
\t \t '<p>Quisque facilisis aliquet dui, ut blandit odio vulputate et. Ut ac nisl turpis. Pellentesque scelerisque massa sit amet ipsum commodo cursus. Aenean eget ante et neque gravida tempor. Phasellus aliquam, purus quis malesuada vestibulum, sem mi cursus justo, a convallis purus dolor non lorem. Nunc dapibus vehicula nisi, eget egestas tellus lacinia vel. Nullam nisl ipsum, vehicula dignissim feugiat eu, semper nec arcu. Duis porttitor ut ex eget commodo. Curabitur accumsan diam ac euismod tincidunt. Cras dui urna, volutpat quis vehicula vitae, rhoncus a lacus. Curabitur ut purus aliquet, venenatis felis in, laoreet massa. Nullam lobortis sollicitudin aliquam. Quisque nec nisl eu sem vulputate venenatis. Proin sagittis erat sit amet sem vestibulum vehicula. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.</p>' 
 
\t ]; 
 

 
\t // Shuffle the paragraphs 
 
\t for (var i = paragraphs.length - 1; !!i; --i) { 
 
\t \t var j = Math.floor(Math.random() * i); 
 
\t \t var p = paragraphs[i]; 
 
\t \t paragraphs[i] = paragraphs[j]; 
 
\t \t paragraphs[j] = p; 
 
\t } 
 

 
\t // Generate the post 
 
\t var post = '<li>'; 
 
\t post += '<article>'; 
 
\t post += '<header><h1>Random Article!</h1></header>'; 
 
\t post += paragraphs.join(''); 
 
\t post += '</article>'; 
 
\t post += '</li>'; 
 

 
\t return post; 
 
}
body { 
 
\t margin: 0; 
 
\t font-family: 'Liberation Sans', Arial, sans-serif; 
 
} 
 

 
h1 { 
 
\t text-align: center; 
 
} 
 

 
#posts { 
 
\t margin: 0 auto; 
 
\t padding: 0; 
 
\t width: 700px; 
 
\t list-style-type: none; 
 
} 
 

 
article h1 { 
 
\t text-align: left; 
 
\t border-bottom: 1px dotted #E3E3E3; 
 
} 
 

 
article p { 
 
\t text-align: justify; 
 
\t line-height: 1.5; 
 
\t font-size: 1.1em; 
 
} 
 

 
#loading { 
 
\t display: none; 
 
\t text-align: center; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<h1>Infinite Scrolling, Demo 2</h1> 
 

 
\t \t <ul id="posts"> 
 
\t \t \t <li> 
 
\t \t \t \t <article> 
 
\t \t \t \t \t <header> 
 
\t \t \t \t \t \t <h1>This Is an Article</h1> 
 
\t \t \t \t \t </header> 
 

 
\t \t \t \t \t <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras vitae suscipit arcu. Praesent pretium orci neque, non egestas massa suscipit non. In urna ligula, pretium ac magna in, consectetur venenatis dui. Etiam id commodo neque, vel semper nunc. Vivamus porttitor condimentum pulvinar. Quisque et consequat mi. Suspendisse luctus, quam in dapibus venenatis, velit erat malesuada lacus, dapibus tincidunt neque ex vitae leo. Suspendisse fermentum sit amet urna eu dignissim. Curabitur vel nibh quis justo volutpat porttitor et tempus sem.</p> 
 

 
\t \t \t \t \t <p>In a luctus purus, in tempus mi. Integer vulputate tincidunt arcu quis aliquet. Maecenas sollicitudin nec nisi sit amet dictum. Curabitur sagittis nulla id sem vulputate, eget blandit nibh ullamcorper. Nam feugiat elementum pharetra. Vestibulum a purus eget mi mattis tincidunt a sed felis. Sed pretium dignissim elementum. Cras est arcu, posuere et justo in, vehicula rutrum elit. Phasellus dictum risus libero, non cursus neque faucibus a. Nunc dignissim at purus vitae condimentum. Curabitur in libero mi.</p> 
 

 
\t \t \t \t \t <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed at tristique nibh, sed congue ligula. Curabitur eu porttitor tellus. Aliquam eu mollis tortor. Donec tortor sapien, molestie eu turpis vel, ultrices pulvinar orci. Aenean sagittis sem sit amet viverra maximus. Morbi id enim ipsum. Curabitur luctus placerat erat ut volutpat. In quis eros mattis, rutrum neque ut, malesuada neque.</p> 
 

 
\t \t \t \t \t <p>Integer erat eros, vestibulum at tortor vitae, sollicitudin finibus est. Aliquam ornare, elit nec gravida sagittis, sapien nibh elementum felis, eu eleifend eros lectus non mi. Nulla vel nisl scelerisque, consectetur nibh vel, malesuada lacus. Nam lobortis accumsan nisl consequat dictum. Praesent eget lobortis lorem. Ut sed ultrices enim. Nam nec ultricies felis.</p> 
 

 
\t \t \t \t \t <p>Donec hendrerit dolor id auctor ullamcorper. Curabitur ut mauris dolor. Quisque vitae cursus eros, ac rutrum sem. Aenean in turpis turpis. Fusce sit amet libero id massa dictum fermentum at eget arcu. Vestibulum eget blandit urna. In eu tristique augue. Phasellus augue risus, porttitor vel arcu nec, tincidunt laoreet tellus. Nam ornare leo dapibus ipsum dictum interdum.</p> 
 

 
\t \t \t \t \t <p>Nulla molestie porttitor justo vitae pharetra. Proin non convallis lacus, eget malesuada metus. Duis aliquam eu massa molestie rhoncus. Vestibulum a malesuada nulla. Morbi at libero tempus, hendrerit quam vitae, auctor eros. Vivamus tincidunt enim a est tincidunt, sed fringilla erat placerat. Nulla cursus, eros sed posuere sagittis, dui est lobortis tellus, id dapibus dui sem eget enim. Vestibulum eleifend lacus velit, ut suscipit nisi bibendum at. Nulla facilisi. Aenean luctus tellus eget nisi vestibulum, eget interdum lectus efficitur.</p> 
 

 
\t \t \t \t \t <p>Quisque facilisis aliquet dui, ut blandit odio vulputate et. Ut ac nisl turpis. Pellentesque scelerisque massa sit amet ipsum commodo cursus. Aenean eget ante et neque gravida tempor. Phasellus aliquam, purus quis malesuada vestibulum, sem mi cursus justo, a convallis purus dolor non lorem. Nunc dapibus vehicula nisi, eget egestas tellus lacinia vel. Nullam nisl ipsum, vehicula dignissim feugiat eu, semper nec arcu. Duis porttitor ut ex eget commodo. Curabitur accumsan diam ac euismod tincidunt. Cras dui urna, volutpat quis vehicula vitae, rhoncus a lacus. Curabitur ut purus aliquet, venenatis felis in, laoreet massa. Nullam lobortis sollicitudin aliquam. Quisque nec nisl eu sem vulputate venenatis. Proin sagittis erat sit amet sem vestibulum vehicula. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.</p> 
 
\t \t \t \t </article> 
 
\t \t \t </li> 
 
\t \t </ul> 
 

 
\t \t <p id="loading"> 
 
\t \t \t <img src="images/loading.gif" alt="Loading…" /> 
 
\t \t </p>

+0

감사합니다 잔뜩. 문서의 높이와 창 때문에 'if ($ (window) .scrollTop()> ($ (document) .height() - $ (window) .height() - 10))'값을 약간 조정해야합니다. 높이는 같은 값입니다. 너무 많은 아약스 요청을 그렇게 빨리 만들고 싶지 않습니다. 그러나이 대답은 나를 많이 도왔다. – alexia

0

$.fn.scrollBottom = function() { 
      return $(document).height() - this.scrollTop() - this.height(); 
     }; 

및 win.scrollTop에 win.scrollBottom()을 (변경 제거

).