Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ajax/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Rails3-使用Kaminari和x2B进行排序和分页;AJAX+;低调的javascript_Ajax_Ruby On Rails 3_Pagination_Unobtrusive Javascript_Kaminari - Fatal编程技术网

Rails3-使用Kaminari和x2B进行排序和分页;AJAX+;低调的javascript

Rails3-使用Kaminari和x2B进行排序和分页;AJAX+;低调的javascript,ajax,ruby-on-rails-3,pagination,unobtrusive-javascript,kaminari,Ajax,Ruby On Rails 3,Pagination,Unobtrusive Javascript,Kaminari,我已经成功地与Kaminari建立了ajax分页 为了添加排序功能,我遵循了这一伟大的原则,并将will_paginate替换为Kaminari 分页效果很好,但排序只是第一次工作,因为sort_列和sort_方向没有更新 我不明白为什么 这是我的密码: 控制器: def index @questions = Question.order(sort_column + " " + sort_direction).page(params[:page]) end .... private d

我已经成功地与Kaminari建立了ajax分页

为了添加排序功能,我遵循了这一伟大的原则,并将will_paginate替换为Kaminari

分页效果很好,但排序只是第一次工作,因为sort_列和sort_方向没有更新

我不明白为什么

这是我的密码:

控制器:

def index
 @questions = Question.order(sort_column + " " +  sort_direction).page(params[:page])
end

....

private

def sort_column
 Question.column_names.include?(params[:sort]) ? params[:sort] :  "created_at"
end

def sort_direction
 %w[asc desc].include?(params[:direction]) ? params[:direction] : "desc"
end
我已将
:remote=>true,:method=>:get
添加到

ApplicationHelper:

def sortable(title = nil, column)
 title ||= column.titleize
 direction = column == sort_column && sort_direction == "asc" ? "desc" : "asc"
 link_to title, params.merge(:sort => column, :direction => direction), :remote => true, :method => :get
end
index.html.erb:

<%= sortable "created_at" %><br/>
<div id="questions"><%= render @questions %></div>
<div id="paginator"><%= paginate @questions, :remote => true %>

正确%>
index.js.erb:

$('#questions').html('<%= escape_javascript(render @questions) %>');
$('#paginator').html('<%= escape_javascript(paginate(@questions, :remote => true).to_s) %>');
$('#问题').html('');
$('#paginator').html('true.to_s)%>');

这是
:remote=>true,:method=>:get
部分的问题吗?如果我删除它,排序可以工作,但是没有ajax。

我希望您建议我看看这个


它可以很容易地实现对数据列的排序。

我想让您看看这个

@products = Product.order("name").page(params[:page])  
它可以很容易地实现对数据列的排序

@products = Product.order("name").page(params[:page])  


我不明白这是一个如何被接受的答案,因为屏幕广播不包括分页。我不明白这是一个如何被接受的答案,因为屏幕广播不包括分页。