2

我以通常的方式使用nested_form_for,但我想向嵌套子级添加动态选择菜单。

我有以下咖啡脚本(改编自'dynamic-select-menus' railscast

jQuery ->
  $( ".controls-row" ).each ->
    $(this).bind "change", ->
      type = $('#expense_type :selected').text()
      if (type == "miles")
        $('#amount_currency').hide()
        $('#km_traveled').show()
      else 
        $('#amount_currency').show()
        $('#km_traveled').hide()

这段代码的问题是它只适用于第一个嵌套元素。我尝试为每个元素添加唯一的 id,但这仅适用于现有元素。新元素都是“蓝图”元素的克隆,并且都具有相同的 ID。

有没有人有更好的方法在嵌套表单中实现动态选择菜单?

4

2 回答 2

0

只需使用正则表达式将“蓝图”ID 更改为独特的。

例如,如果您正在加载部分内容,您可以使用 Javascript 的替换来更改默认 ID。

于 2012-11-13T06:11:32.453 回答
0

我用这段代码解决了它:

jQuery ->
  $(document).on "nested:fieldAdded", (event) ->
    $( ".controls-row" ).each ->
        $(this).find('#expense_type').bind "change", ->
            type = $(this).parent().find('#expense_type :selected').text()
            if (type == "km")
                $(this).parent().find('#payment_method').addClass('hidden').hide()              
                $(this).parent().find('#amount_in_currency').addClass('hidden').hide()
                $(this).parent().find('#amount_currency').addClass('hidden').hide()
                $(this).parent().find('#km_traveled').removeClass('hidden').show()
            else 
                 $(this).parent().find('#payment_method').removeClass('hidden').show()
                 $(this).parent().find('#amount_currency').removeClass('hidden').show()
                 $(this).parent().find('#amount_in_currency').removeClass('hidden').show()
                 $(this).parent().find('#km_traveled').addClass('hidden').hide()
        $(this).find('#expense_type').trigger('change')

  $(document).trigger("nested:fieldAdded")
于 2012-11-16T19:30:00.977 回答