gpt4 book ai didi

ajax - 通过 Ajax 使用 kaminari 进行多页分页

转载 作者:行者123 更新时间:2023-12-03 21:40:19 25 4
gpt4 key购买 nike

我想通过 Ajax 使用 Kaminari 应用多个分页,现在这是我的 Controller 代码

def user_note
@user = current_user
@notes = Bookmark.where('user_id = ? && note is not NULL',current_user.id).order('created_at DESC').page(params[:page_1]).per(4)

@bookmarks = Bookmark.where('user_id = ? && note is NULL',current_user.id).order('created_at DESC').page(params[:page_2]).per(4)

respond_to do |format|
format.html
format.xml{ render :xml => @user}
end end

现在对于 View ,我有两个部分来呈现这个数组
<div id="bookmarks">
<%= render :partial =>"users/bookmark",:locals => { :bookmark => @bookmarks} %>
</div>
<%= paginate @bookmarks,:remote => true, :param_name => 'page' %>

内部部分是
<% bookmark.each do |bookmar| %>
<%= render :partial => 'show_bookmark.html.erb' , :locals => { :bookma => bookmar} %>
<%end%>

分页更新脚本在单独的文件中处理
$('#bookmarks').html('<%= escape_javascript render(:partial =>"users/bookmark",:locals => { :bookmark => @bookmarks}) %>');
$('#paginator').html('<%= escape_javascript(paginate(@bookmarks, :remote => true).to_s) %>');

但是通过做每件事,它不会更新到页面状态,也不会更新到页面中的包含。

最佳答案

你缺少在这一行传递参数

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

我觉得应该是这样
$('#paginator').html('<%= escape_javascript(paginate(@bookmarks, :remote => true, :param_name => 'page_2').to_s) %>');

你也在这一行传递了错误的参数
<%= paginate @bookmarks,:remote => true, :param_name => 'page' %>

应该是这样的
<%= paginate @bookmarks,:remote => true, :param_name => 'page_2' %>

并请检查您是否正确地将响应发送到 JS 文件。

关于ajax - 通过 Ajax 使用 kaminari 进行多页分页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9016943/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com