javascript – will_paginate页面链接问题

前端之家收集整理的这篇文章主要介绍了javascript – will_paginate页面链接问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我目前有一个评论模型,在微博下发布,两者都显示在同一页面上.问题是两者都显示在同一页面上,并且两者都是分页的,我试图用facebook方法进行微观测量.以下是以下问题:

两个分页链接变成这个href =“/ users / 2?page = 2”而不是href =“/ users / 2 / micropost?page = 2”或者href =“/ users / 2 / comment?page = 2 ”.我不确定如何解决这个问题.这是我的一些代码.所有建议都非常感谢!

Micropost渲染HTML

<table class="microposts">
<% if microposts.any? %>
<%= render microposts %>
<%= will_paginate microposts,:page_links => false %>
<% else %>
<div class="EmptyContainer"><span class='Empty'>Add a thread!</span></div>
<% end %>
</table>

评论部分HTML

<div id='CommentContainer-<%= micropost.id%>' class='CommentContainer Condensed2'>
<div class='Comment'>
<%= render :partial => "comments/form",:locals => { :micropost => micropost } %>
</div>
<div id='comments'>
  <% comments = micropost.comments.paginate(:per_page => 5,:page => params[:page]) %>
  <%= render comments %>
  <%= will_paginate comments,:class =>"pagination" %>
</div>
</div>

显示页面用户控制器

def show
    @user = User.find(params[:id])
    @comment = Comment.find(params[:id])
    @micropost = Micropost.new
    @comment = Comment.new
    @comment = @micropost.comments.build(params[:comment])
    @comments = @micropost.comments.paginate(:page => params[:page],:per_page => 5)
    @microposts = @user.microposts.order('created_at DESC').paginate(:per_page => 10,:page => params[:page])
      respond_to do |format|
      format.html
      format.js
     end
  end

解决方法

问题在于为每个页面创建URL的will_paginate方式(它与jQuery没有任何关系).

通过设计,will_paginate会尽力猜测页面用户的基本URL是什么(在内部它使用控制器/动作来做到这一点).然后将该基本URL与传递给will_paginate助手的任何额外参数组合使用:params和succesive页码.

目前(will_paginate 3.0.3),为了覆盖此默认行为,您需要编写自定义LinkRenderer类.下面是这样一个类的例子 – 它使用了新的额外选项:base_link_url,可以传递给will_paginate视图助手.然后,在创建分页链接时,将传递的字符串用作基础.如果:未传递base_link_url选项,则它将回退到默认行为.

将以下类放在某个地方,rails可以在加载时找到它(例如/ lib,只要你将/ lib添加到application.rb中的自动加载路径):

# custom_link_renderer.rb
class CustomLinkRenderer < WillPaginate::ActionView::LinkRenderer
  def prepare(collection,options,template)
    @base_link_url = options.delete :base_link_url
    @base_link_url_has_qs = @base_link_url.index('?') != nil if @base_link_url
    super
  end

  protected
  def url(page)
    if @base_link_url.blank?
      super
    else
      @base_url_params ||= begin
        merge_optional_params(default_url_params)
      end

      url_params = @base_url_params.dup
      add_current_page_param(url_params,page)

      query_s = []
      url_params.each_pair {|key,val| query_s.push("#{key}=#{val}")}

      if query_s.size > 0
        @base_link_url+(@base_link_url_has_qs ? '&' : '?')+query_s.join('&')
      else
        @base_link_url
      end
    end
  end
end

用法

# in your view
will_paginate collection,:renderer => CustomLinkRenderer,:base_link_url => '/anything/you/want'

现在回到你的案子.到这个时候你可能会看到解决方案 – 你可以在一个页面上有两个带有不同基本URL的will_paginate小部件,为这两个提供不同的:base_link_url选项.

猜你在找的JavaScript相关文章