[英]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.