1

我想根据用户选择的国家/地区自动选择县。
我的意思是,如果用户选择美国,它会显示加利福尼亚州、纽约州等地区的选择

国家模式有

  • ID
  • 姓名

模式有

  • ID
  • country_id

现在我像这样展示这些字段

<% resource.build_user_profile if resource.user_profile.nil? %>
<%= form_for(resource, :as => resource_name, :url => registration_path(resource_name), :html => { :method => :put, :class => 'form-horizontal' }) do |f| %>
  <%= devise_error_messages! %>

<%= f.fields_for :user_profile do |profile_form| %>

 <label class="control-label"><%= profile_form.label :country_id %></label>
 <%= profile_form.collection_select("country_id", Country.find(:all), :id, :name_en) %>

 <label class="control-label"><%= profile_form.label :prefecture_id %></label>
 <%= profile_form.collection_select("prefecture_id", Prefecture.find(:all), :id, :name) %>

<% end %>
4

1 回答 1

0

尝试像这样改变形式

<%= f.label :country_id %><br />
<%= f.collection_select :country_id, Country.all, :id, :name_en, include_blank: true %>

<%= f.label :state_id, "State or Province" %><br />
<%= f.grouped_collection_select :prefecture_id, Country.all, :prefectures, :name_en, :id, :name, include_blank: true %>

并粘贴到正确的咖啡文件中(如果模型profileprofile.js.coffee)如果它在文件名和文件内部的其他模型更改配置文件中

jQuery ->
  $('#resource_name_user_profile_prefecture_id').parent().hide()
  prefectures = $('#resource_name_user_profile_prefecture_id').html()
  $('#resource_name_user_profile_country_id').change ->
    country = $('#resource_name_user_profile_country_id :selected').text()
    escaped_country = country.replace(/([ #;&,.+*~\':"!^$[\]()=>|\/@])/g, '\\$1')
    options = $(prefectures).filter("optgroup[label='#{escaped_country}']").html()
    if options
      $('#resource_name_user_profile_prefecture_id').html(options)
      $('#resource_name_user_profile_prefecture_id').parent().show()
    else
      $('#resource_name_user_profile_prefecture_id').empty()
      $('#resource_name_user_profile_prefecture_id').parent().hide()
于 2012-12-24T20:02:11.450 回答