繁体   English   中英

使用模型关联将will_paginate gem

[英]will_paginate gem using model associations

我正在使用will_paginate gem,并且尝试通过模型关联来利用它。 现在,我有“组”和“帖子”模型,其中每个组都有一个帖子列表。 但是,当我尝试使用will_paginate链接这些模型时,它不起作用。 但是我在终端中使用Group.find(15).posts.order('created_at DESC')并且可以正常工作。 不知道我是否缺少某些东西,或者是否与我处理零件有关。

组show.html.erb

<%= render "posts/index" %> 

发布_index.html.erb

<%= render 'posts/posts' %>
...
<%= will_paginate @posts %>

发布_posts.html.erb

<% @group.posts.each do |post| %>
  <%= render 'posts/post', post: post, group: @group %>
<% end %>

发布_post.html.erb

...
<%= post.caption %>

发布index.js.erb

$('#posts').append("<%= escape_javascript(render 'posts')%>");
$('.pagination').replaceWith('<%= escape_javascript will_paginate(@posts) %>');

scroll.js

$(document).ready(function() {
if ($('.pagination').length) {
$(window).scroll(function() {
  var url = $('.pagination .next_page').attr('href');
  if (url && $(window).scrollTop() > $(document).height() - $(window).height() - 50) {
    $('.pagination').text("Please Wait...");
    return $.getScript(url);
  }
 });
 return $(window).scroll();
}
});

组控制器

def show
    @group = Group.find(params[:id])
    @posts = @group.posts.paginate(page: params[:page], per_page: 3).order('created_at DESC')
end

我也尝试了@posts = Post.paginate(page: params[:page], per_page: 3).order('created_at DESC')但它似乎不起作用。 我的帖子列表没有降序排列,也没有三列。 有关在使用多个模型时如何利用此gem的任何建议?

根据关于gem的文档,分页调用应为paginate(:page => params[:page], :per_page => 10)而不是paginate(page: params[:page], per_page: 3)在您的代码中。

那就是你的问题所在。 如果仍不能解决问题,您也可以尝试:

def show
  @group = Group.find(params[:id])
  @posts = @group.posts.order('created_at DESC').paginate(:page => params[:page], :per_page => 3)
end

在应用程序中使用分页时,我要做的一件事是仅在完成查询结果后才进行分页。

因此,问题在于您正确设置了@posts ,但是随后您不使用它而是遍历@group.posts ,在视图中:

# posts/_index.html.erb
<%= render 'posts/posts' %>
...
<%= will_paginate @posts %>

# posts/_posts.html.erb 
<% @group.posts.each do |post| %>
  <%= render 'posts/post', post: post, group: @group %>
<% end %>

而是这样做:

# posts/_posts.html.erb 
<% @posts.each do |post| %>
  <%= render 'posts/post', post: post, group: @group %>
<% end %>

请注意, <%= will_paginate @posts %>部分绘制导航控件。 帖子列表来自render posts/posts

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM