неопределенный метод `model_name' для NilClass:Class, передача формы между представлениями

Только начинаю изучать рельсы, и я пытаюсь передать форму из одного представления в другое... Я предполагаю, что способ сделать это - использовать частичный рендеринг.

Я хочу передать часть формы, содержащейся в /users/form, в index.html.erb в домашнем представлении. Я просто хочу создать нового пользователя, но из index.html.erb в домашнем представлении.

Соответствующий код:

_form.html.erb (в представлении пользователей)

<%= simple_form_for(@user) do |f| %>
  <%= f.error_notification %>

  <div class="form-inputs">
    <%= f.input :email %>
    <%= f.input :condition, :hint => 'what should we look up for you?'%>
  </div>

  <div class="form-actions">
    <%= f.button :submit, 'Begin curation' %>

  </div>
<% end %>

модель пользователей (user.rb)

class User < ActiveRecord::Base
  attr_accessible :condition, :email, :name
end

users_controller.rb

class UsersController < ApplicationController
  # GET /users
  # GET /users.json
  def index
    @users = User.all

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @users }
    end
  end

  # GET /users/1
  # GET /users/1.json
  def show
    @user = User.find(params[:id])

    respond_to do |format|
      format.html # show.html.erb
      format.json { render json: @user }
    end
  end

  # GET /users/new
  # GET /users/new.json
  def new
    @user = User.new

    respond_to do |format|
      format.html # new.html.erb
      format.json { render json: @user }
    end
  end

  # GET /users/1/edit
  def edit
    @user = User.find(params[:id])
  end

  # POST /users
  # POST /users.json
  def create
    @user = User.new(params[:user])

    respond_to do |format|
      if @user.save
        format.html { redirect_to @user, notice: 'Thanks for sharing. We will be back with your curated information in 2-3 days time!' }
        format.json { render json: @user, status: :created, location: @user }
      else
        format.html { render action: "new" }
        format.json { render json: @user.errors, status: :unprocessable_entity }
      end
    end
  end

  # PUT /users/1
  # PUT /users/1.json
  def update
    @user = User.find(params[:id])

    respond_to do |format|
      if @user.update_attributes(params[:user])
        format.html { redirect_to @user, notice: 'User was successfully updated.' }
        format.json { head :no_content }
      else
        format.html { render action: "edit" }
        format.json { render json: @user.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /users/1
  # DELETE /users/1.json
  def destroy
    @user = User.find(params[:id])
    @user.destroy

    respond_to do |format|
      format.html { redirect_to users_url }
      format.json { head :no_content }
    end
  end
end

Я уверен, что это легко исправить, я просто не знаю синтаксиса. Я проверил другие места и не нашел ничего, что помогло бы мне.


person Brian Ambielli    schedule 03.02.2013    source источник


Ответы (1)


Держу пари, что у вас нет определенной переменной @user. SimpleForm нужна переменная экземпляра из правильной модели, чтобы эффективно работать с полями ввода. Это дает эту ошибку, если ваша переменная не создана.

model_name вызывается в NilClass. NilClass — это ваш @user.

Попробуйте это вместо этого:

<%= simple_form_for User.new do |f| %>
...

Обновлять

# app/controllers/users_controller.rb
class UsersController < ApplicationController

  before_filter :prepare_user_form, only: [:index, :new]

  protected

  def prepare_user_form
    @user = User.new
  end

end


# _form.html.erb
<%= simple_form_for @user do |f| %>
...
person mathieugagne    schedule 03.02.2013
comment
Я тоже так думаю, но как это сделать? мне просто объявить его в верхней части моего index.html.erb? - person Brian Ambielli; 04.02.2013
comment
Это сработало! ты обалденный! Большое спасибо. Если вы не возражаете объяснить, когда вы должны использовать @variables вместо только имени переменной? - person Brian Ambielli; 04.02.2013
comment
Форма, подобная этой, использующая Model.new, никогда бы не обновилась должным образом, если бы она была для простого CRUD. Предположим, что это ваша «новая» форма, и действие create не прошло проверку, чтобы вы снова отобразили форму. Ваша вновь созданная переменная @model не будет использоваться в форме. У вас будет совершенно новый объект Model.new. ПОТЕРПЕТЬ НЕУДАЧУ. Даже в вашем случае у вас должен быть параметр before_filter, устанавливающий переменную для всех действий, разделяющих этот частичный _form. Позвольте мне обновить мой ответ. В основном я использую Model.new только для форм AJAX. - person mathieugagne; 04.02.2013
comment
хорошо, круто, я думаю, что это имеет смысл для меня. Итак, если бы у меня было другое представление (скажем, покупка), и я хотел бы добавить эту форму в индекс. Я бы зашел в контроллер и добавил :shopping в единственную: часть before_filter, чтобы форма использовала ту же переменную и в этом рендеринге формы? - person Brian Ambielli; 04.02.2013
comment
Если это тот же контроллер, то да. Ваш пример имел бы смысл, если бы это было действие :search UsersController. Вот почему я склоняюсь к тому, чтобы многие из этих частичных _form были AJAX. Вы обновляете Дом, поэтому нет необходимости передавать эту переменную @user - person mathieugagne; 04.02.2013