ajax - Rails3 - 使用 Kaminari + AJAX + 不显眼的 javascript 进行排序和分页

标签 ajax ruby-on-rails-3 pagination unobtrusive-javascript kaminari

我已经成功使用 Kaminari 设置了 ajax 分页。

为了添加排序功能,我遵循了这个伟大的 Railscast并将 will_paginate 替换为 Kaminari。

分页工作得很好,但排序只是第一次工作,因为 sort_column 和 sort_direction 没有更新。

我不明白为什么。

这是我的代码:

Controller :

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 添加到

应用程序助手:

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) %>');

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

最佳答案

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

http://asciicasts.com/episodes/254-pagination-with-kaminari

关于ajax - Rails3 - 使用 Kaminari + AJAX + 不显眼的 javascript 进行排序和分页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5759578/

相关文章:

wordpress - 多个查询的一个分页(或如何对一个查询进行分组)

java - REST 网络应用程序中的分页

javascript - onchange 事件监听器未在文本框上触发

ruby-on-rails - 设计路由: is there a way to remove a route from Rails. application.routes?

jquery - :remote => true Ajax call in Rails not working

ruby-on-rails - 如何在具有名为 'attribute' 的列的数据库上使用 ActiveRecord ? (危险属性错误)

php - cakePHP 分页和 passedArgs

java - struts2如何运行它的validate方法?

java - ReSTLet、CLAP、Ajax 和 block 超时

javascript限制?