我有一个轨道应用程序。当我单击一个按钮时,我希望它将一些新数据加载到我的控制器中的@posts 中,并在页面上的渲染中显示出来。
在我看来,我有三个按钮:
<div class="span6 offset3" id="user_post_area_button">
<div id="type_group" class="btn-group" data-toggle="buttons-radio">
<button class="radio_button" id="radio_button_zero" data-value="0">0</button>
<button class="radio_button" id="radio_button_one" data-value="1">1</button>
<button class="radio_button" id="radio_button_two" data-value="2">2</button>
</div>
</div>
当我单击其中一个时,我希望页面的某些部分发生变化。这是我要更改的部分(我希望它使用新的@posts 呈现):
<div class="render_post">
<%= render 'pages/singlePost' %>
</div>
我使用这个 .js.coffee 代码:
$ ->
$("button.radio_button").click (e) ->
e.preventDefault();
list_status = $(this).data("value")
if list_status == 0
$("#radio_button_zero").addClass('active')
$("#radio_button_one").removeClass('active')
$("#radio_button_two").removeClass('active')
$.post '/lelist/' + list_status
else if list_status == 1
$("#radio_button_zero").removeClass('active')
$("#radio_button_one").addClass('active')
$("#radio_button_two").removeClass('active')
$.post '/lelist/' + list_status
else if list_status == 2
$("#radio_button_zero").removeClass('active')
$("#radio_button_one").removeClass('active')
$("#radio_button_two").addClass('active')
$.post '/lelist/' + list_status
这是我的控制器:
class PagesController < ApplicationController
def lelist
if current_user && params[:list_status] == 0
@posts = Post.where("created_at <= ? AND status = ?", Time.now, 0).order("created_at DESC").page(params[:page]).per_page(10)
elsif current_user && params[:list_status] == 1
@posts = Post.where("created_at <= ? AND status = ?", Time.now, 1).order("created_at DESC").page(params[:page]).per_page(10)
elsif current_user && params[:list_status] == 2
@posts = Post.where("created_at <= ? AND status = ?", Time.now, 2).order("created_at DESC").page(params[:page]).per_page(10)
elsif !current_user || current_user
@posts = Post.where("created_at <= ? AND status = ?", Time.now, 0).order("created_at DESC").page(params[:page]).per_page(10)
end
end
end
我只是不知道如何使这项工作。一些建议?