无尽的滚动will_paginate在轨道上的红宝石中不起作用

时间:2013-05-27 05:32:22

标签: javascript ruby-on-rails ruby ruby-on-rails-3 erb

我正在关注此railcasts以在我的rails应用程序中集成无尽的滚动。我在这里这样做..

static_pages_controller.rb -

def home
  @posts = Post.paginate(page: params[:page],:per_page => 10)
end

home.html.erb -

<div id="posts_list" style="height:300px; overflow:scroll">
   <%= render :partial => "posts/posts" %>
   <p id="loading">Loading more page results...  </p>
</div>

部分帖子/帖子---

<% if @posts.any? %>
  <div id="postlist">
  <ul>
    <%= render partial: 'posts/posts_item', collection: @posts %>
  </ul>
  </div>
<% end %>

部分帖子/ posts_item -

<li><%= posts_item.title %></li>
<li><%= posts_item.content %></li>

我的static_pages / home.js.erb -

page.insert_html :bottom, :posts, :partial => @posts
  if @posts.total_pages > @posts.current_page
   page.call 'checkScroll'
  else
   page[:loading].hide
  end

和我的资产/ javascripts / endless_page.js -

var currentPage = 1;

 function checkScroll() {
   if (nearBottomOfPage()) {
    currentPage++;
    new Ajax.Request('/?page=' + currentPage, {asynchronous:true, evalScripts:true, method:'get'});
   }    else {
     setTimeout("checkScroll()", 250);
  }
}

function nearBottomOfPage() {
  return scrollDistanceFromBottom() < 150;
}

function scrollDistanceFromBottom(argument) {
  return pageHeight() - (window.pageYOffset + self.innerHeight);  
}

function pageHeight() {
  return Math.max(document.body.scrollHeight, document.body.offsetHeight);
}

document.observe('dom:loaded', checkScroll);

但我无休止的滚动不起作用。我不知道我在哪里做错了。请帮忙。

0 个答案:

没有答案