微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – RJS:Ajaxified select_tag

由于我没有在last question上得到预期的答案,我会尝试简化和缩小我的问题:

How can I build a dropdown-menu that uses AJAX (no submit-button) to call the show action of a certain controller?

给出以下内容

模型关联是类别HABTM项目,因此下拉菜单包含所有类别名称.

应该实现下拉菜单的视图部分.下拉菜单下方是一个项目列表,应根据下拉菜单中的选择进行更改:

   <!-- placeholder for AJAX dropdown menu -->

   <!-- list of projects related to categories chosen by the select tag -->
   <ul class="projects">
     <% @projects.each do |_project| %>
       <li>
         <%= link_to(_project.name, _project) %>
       </li>
     <% end %>
   </ul>

具有应该调用的show-action的Categories控制器:

class CategoriesController < ApplicationController
  def show
    # params[:id] should be the choice the user made in the dropdown menu
    @category = Category.find(params[:id])
    @projects = @category.projects.find(:all)

    respond_to do |format|
      format.html # show.html.erb
      format.js   # needed for ajax response?
    end
  end

  def index
    @projects = Category.find(params[:id]).projects.find(:all)
    @category = @project.categories.first

    respond_to do |format|
      format.html # index.html.erb
    end
  end 
end

在Categories控制器中调用show-action的路径:

category GET    /categories/:id    {:controller=>"categories", :action=>"show"}

你会如何实现这个?任何帮助都是非常苛刻的!

解决方法:

这个怎么样:

<% form_for :category, :url => { :action => "show" } do |f| %>
  <%= select_tag :id, options_from_collection_for_select(Category.find(:all), :id, :name),
  { :onchange => "this.form.submit();"} %>
<% end %>

这将调用传统的html调用,因此它将刷新整个页面(并响应format.html).

然后控制器将通过提交的[:id]找到类别

@category = Category.find(params[:id])

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐