RailsCastsの手順に従って、ネストされたモデル フォームをセットアップしました。(これにより、1 つのフォーム内に複数のモデルを含めることができます。) 最初のコードは、ネストされたモデルを構築するためにコントローラーの新しいメソッドにコードを追加するまで機能しませんでした (以下を参照)。2 番目の部分では、ajax を使用してフィールドを追加および削除しました。
Ajax の削除は回答を削除するために機能しましたが、新しい回答フィールドを追加するための ajax は機能しませんでした。これは、ajaxをコントローラーコードに接続する必要があるためだと思いますが、その方法がわかりません。
これは、コントローラーに追加したコードです。
def new
@survey = Survey.new
@question = @survey.questions.build
@question.answers.build
end
これは他の関連コードです (レールキャストから):
<%= link_to_add_fields "Add answer", f, :answers %>
それは次のメソッドを呼び出します:
def link_to_add_fields(name, f, association)
new_object = f.object.send(association).klass.new
id = new_object.object_id
fields = f.fields_for(association, new_object, child_index: id) do |builder|
render(association.to_s.singularize + "_fields", f: builder)
end
link_to(name, '#', class: "add_fields", data: {id: id, fields: fields.gsub("\n", "")})
end
次のjqueryを呼び出します:
$('form').on 'click', '.add_fields', (event) ->
time = new Date().getTime()
regexp = new RegExp($(this).data('id'), 'g')
$(this).before($(this).data('fields').replace(regexp, time))
event.preventDefault()