私のアプリケーションのドロップダウンメニュー(select_tagによって作成された)は、ユーザーがドロップダウンメニューの値を変更して[実行]ボタンを押すとすぐに、filter-category-actionを呼び出す必要があります。
ここで、[実行]ボタンを削除し、ユーザーがドロップダウンメニューの値を変更するとすぐに、オブザーバー(observe_field?)にfilter-category-actionを呼び出させたいと思います。
以下に私が書いたコードを示します。「実行」ボタンを使用して機能しますが、ドロップダウンメニューの値を変更するだけでは機能しません。私のobserve_category_select-helperの何が問題になっていますか?
表示-ドロップダウンメニューとプロジェクトリストを含む部分
<!-- drop down menu -->
<% form_tag(filter_category_path(:id), :method => :post, :class => 'categories') do %>
<label>Categories</label>
<%= select_tag(:category, options_for_select(Category.all.map {|category| [category.name, category.id]}, @category_id)) %>
<!-- i would like to get rid of this button -->
<%= submit_tag "Go" %>
<% end %>
<!-- list of projects related to categories chosen in drop down menu -->
<ul class="projects">
<% @projects.each do |_project| %>
<li>
<%= link_to(_project.name, _project) %>
</li>
<% end %>
</ul>
<%= observe_category_select -%>
HelperMethod
def observe_category_select
observe_field(
:category,
:url => filter_category_path(:id),
:with => 'category',
:on => 'change'
)
end
Javascript-HelperMethodの出力
<script type="text/javascript">
//<![CDATA[
new Form.Element.EventObserver('category', function(element, value) {
new Ajax.Request('/categories/id/filter', {asynchronous:true, evalScripts:true, parameters:'category=' + encodeURIComponent(value) + '&authenticity_token=' + encodeURIComponent('edc8b20b701f72285068290779f7ed17cfc1cf8c')})
}, 'change')
//]]>
</script>
カテゴリコントローラー
class CategoriesController < ApplicationController
def show
@category = Category.find(params[:id])
@category_id = @category.id
@projects = @category.projects.find(:all)
respond_to do |format|
format.html # index.html.erb
end
end
def index
@projects = Category.find(params[:id]).projects.find(:all)
respond_to do |format|
format.html # index.html.erb
end
end
def filter
@category = Category.find(params[:category])
@category_id = @category.id
@projects = @category.projects.find(:all)
respond_to do |format|
format.html # index.html.erb
end
end
終わり
'レーキルートの出力| grepフィルター '
filter_category POST /categories/:id/filter {:controller=>"categories", :action=>"filter"}
formatted_filter_category POST /categories/:id/filter.:format {:controller=>"categories", :action=>"filter"}