2

我的主页中有一个导航选项卡(twitter-bootstrap),带有 2 个选项卡。在每个选项卡下,我呈现不同的集合:

home_controller.rb:

def index
  @deleted_posts = Post.all.where(status: "deleted").paginate(page: params[:page], per_page: 5)
  @edited_posts = Post.all.where(status: "edited").paginate(page: params[:pr_page], per_page: 5)
end

index.html.erb:

<div class="tabbable"> 
  <ul class="nav nav-pills">
    <li class="active"><a href=<%="#tabDeleted"%> data-toggle="tab"><%= t "deleted" %></a></li>
    <li><a href=<%= "#tabEdited" %> data-toggle="tab"><%= "edited" %></a></li>
  </ul>

  <div class="tab-content">
    <div class="tab-pane active" id=<%="tabDeleted" %>>
      <%= render @deleted_posts %>
      <%= will_paginate @deleted_posts, renderer: BootstrapPagination::Rails %>
    </div>
    <div class="tab-pane" id=<%="tabEdited" %>>
      <%= render @edited_posts %>
      <%= will_paginate @edited_posts, renderer: BootstrapPagination::Rails, :param_name => "pr_page" %>
    </div>
  </div>
</div>

分页在第一个选项卡 (deleted_posts) 中工作正常。

当我切换到第二个选项卡(edited_posts)时,第一页显示正确,尽管我的 url 仍然显示第一个选项卡的页面参数:

 http://localhost:3000/home/index?page=3 

当我尝试转到另一个页面时,它会将我定向到第一个选项卡的第一页(deleted_posts),并且页面参数只是被添加到 url:

http://localhost:3000/home/index?page=3&pr_page=2

我如何解决它?也许这实际上是一个问题:由于 Twitter Bootstrap nav-tabs 不向 url 添加参数,我的应用程序如何知道用户在哪个选项卡中?以及如何将页面参数从错误的选项卡删除到 url(因为它会将两个选项卡的页面参数都添加到 url)?

4

1 回答 1

2

指定:param_name两个will_paginate函数调用。仅指定:param_name一个调用使其将默认:page参数添加到两个分页中。

例如:

  <%= will_paginate @deleted_posts, renderer: BootstrapPagination::Rails, :param_name => "deleted_posts" %>

  <%= will_paginate @edited_posts, renderer: BootstrapPagination::Rails, :param_name => "edited_posts" %>
于 2015-01-18T21:06:20.477 回答