Проблема с Railscast #197 — Форма вложенной модели, часть 2

Я пытаюсь внедрить Ryan's Railscast #197 в систему с вопросами, ответами и опциями (множественный выбор). http://railscasts.com/episodes/197-nested-model-form-part-2.

  • Я успешно реализовал вложение среди этих форм/частей.
  • Более простой способ «флажок» для удаления записей работает правильно.
  • Проблема возникает, когда я пытаюсь добавить/удалить записи.

Я скопировал код точно так, как он появляется в его Railscast:

#new.html.erb
<%= javascript_include_tag :defaults, :cache => true %>
<% f.fields_for :in_options do |builder| %>
  <%= render "option_fields", :f => builder %>
<% end %>

#_option_fields.html.erb partial
<%= f.hidden_field :_destroy %>
<%= link_to_function "remove", "remove_fields(this)" %>

#application_helper.rb (exact same as #197)
  def link_to_remove_fields(name, f)
    f.hidden_field(:_destroy) + link_to_function(name, "remove_fields(this)")
  end

  def link_to_add_fields(name, f, association)
    new_object = f.object.class.reflect_on_association(association).klass.new
    fields = f.fields_for(association, new_object, :child_index => "new_#{association}") do |builder|
      render(association.to_s.singularize + "_fields", :f => builder)
    end
  link_to_function(name, h("add_fields(this, \"#{association}\", \"#{escape_javascript(fields)}\")"))
  end

#application.js (exact same as #197. I have an Event.addbehavior below this code.)
function remove_fields(link) {
  $(link).previous("input[type=hidden]").value = "1";
  $(link).up(".fields").hide();  
}

function add_fields(link, association, content) {
  var new_id = new Date().getTime();
  var regexp = new RegExp("new_" + association, "g")
  $(link).up().insert({
    before: content.replace(regexp, new_id)
  });
}

2 проблемы:

  • Когда я нажимаю на ссылку «удалить», она не удаляется, а просто перемещает страницу вверх или вниз.
  • Когда я включаю link_to_add_fields "Добавить ответ", f, :answers, я получаю неопределенный метод `klass' для nil:NilClass.

------ПРОГРЕСС------

Если я перемещаю функцию remove_fields(link) в верхнюю часть new.html.erb, ссылка удаления работает. Это означает, что у меня проблема с доступом к функции в моем application.js. Вот моя сжатая структура.

# layout forms.html.erb
<html>
  <head>    
    <%= stylesheet_link_tag "global", "forms", "candidateCreateProfile", "LiveValidation", "formsAccount", :cache => true %>
    <%= javascript_include_tag :defaults, "LiveValidation" %>
  </head>
  <body>
    <%= yield %>
  </body>
</html>

# new.html.erb
<%= stylesheet_link_tag "interviewQuestions" %>
<%= javascript_include_tag "effects", "lowpro", "toggle", :cache => true %>
...#everything else, including my call to remove_fields

person sscirrus    schedule 18.06.2010    source источник
comment
вот решение: stackoverflow. com/questions/8895193/   -  person suely    schedule 05.03.2012


Ответы (5)


Для тех, у кого все еще есть проблема с неопределенным методом `klass' для nil:NilClass, см. следующий поток — has_many: через вложенную_форму, которая может создавать несколько экземпляров

person jibiel    schedule 19.05.2011

Просто наткнулся на этот вопрос - если это поможет, используйте этот удивительный гем вложенной формы Райана Бейтса.

Вот рельсовая трансляция.

person weltschmerz    schedule 30.03.2013

Убедились ли вы, что приложение... js включено в вывод? Возможно, вам потребуется отредактировать макет.

person thomasfedb    schedule 18.06.2010
comment
У меня есть ‹%= stylesheet_include_tag :defaults %› в моем макете, который называется «формы». application.js хранится в /public/javascripts. - person sscirrus; 18.06.2010
comment
откройте исходный код страницы и проверьте, включен ли он, возможно, вы используете неправильный макет для этого контроллера/действия? - person thomasfedb; 19.06.2010

В моем случае javascript так не назывался, я меняю запрос на:

link_to name, '#', onclick: "add_fields(this,'#{association}','#{escape_javascript(fields)}')";
person user2834919    schedule 01.10.2013

Вы используете синтаксис библиотеки прототипов вместо jQuery. Посетите страницу эпизода и найдите часть используемого кода, где представлены как прототип, так и синтаксис jQuery.

person alucillo36    schedule 14.01.2014