Неопределенный метод `collect'для nil:NilClass

Может кто-нибудь помочь мне с этой ошибкой?

NoMethodError в сообщениях # создать

Показ C:/Users/User/Documents/website/app/views/posts/_form.html.erb, где поднята строка #24:

неопределенный метод `collect'для nil:NilClass

Извлеченный источник (вокруг строки № 24):

23: <% = f.label: категория%>
24: <% = f.select: categoryoria_id, @ategoria.collect {| c | [c.name, c.id]}%>

Трассировка включения шаблона: app/views/posts/new.html.erb

Мой _form.html.erb

<%= form_for(@post, :html => { :multipart => true }) do |f| %>
  <% if @post.errors.any? %>
    <div id="error_explanation">
      <h2><%= pluralize(@post.errors.count, "error") %> prohibited this post from being saved:</h2>

      <ul>
      <% @post.errors.full_messages.each do |msg| %>
        <li><%= msg %></li>
      <% end %>
      </ul>
    </div>
  <% end %>

  <div class="field">
    <%= f.label :titulo %><br />
    <%= f.text_field :titulo %>
  </div>
  <div class="field">
    <%= f.label :conteudo %><br />
    <%= f.text_area :conteudo %>
  </div>
  <div class="field">
    <%= f.label :categoria %><br />
     <%= f.select :categoria_id, @categoria.collect { |c| [ c.name, c.id ] } %>
  </div>
  <br />
  <div class="field">
  <%= f.file_field :avatar %>
  </div>
  <br />
  <div class="actions">
    <%= f.submit %>
  </div>
  <br />
<% end %>

Мой контроллер:

class PostsController < ApplicationController
  # GET /posts
  # GET /posts.json
  def index
    @posts = Post.all
    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @posts }
    end
  end

  # GET /posts/1
  # GET /posts/1.json
  def show
    @post = Post.find(params[:id])

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

  # GET /posts/new
  # GET /posts/new.json
  def new
    @post = Post.new
    @categoria = Categorium.all
    respond_to do |format|
      format.html # new.html.erb
      format.json { render json: @post }
    end
  end

  # GET /posts/1/edit
  def edit
    @post = Post.find(params[:id])
    @categoria = Categorium.all
  end

  # POST /posts
  # POST /posts.json
  def create
    @post = Post.new(params[:post])

    respond_to do |format|
      if @post.save
        format.html { redirect_to @post, notice: 'Post was successfully created.' }
        format.json { render json: @post, status: :created, location: @post }
      else
        format.html { render action: "new" }
        format.json { render json: @post.errors, status: :unprocessable_entity }
      end
    end
  end

  # PUT /posts/1
  # PUT /posts/1.json
  def update
    @post = Post.find(params[:id])

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

  # DELETE /posts/1
  # DELETE /posts/1.json
  def destroy
    @post = Post.find(params[:id])
    @post.destroy

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

5 ответов

Решение

Ваш new действие определяет @categoria, который затем используется по вашему мнению.

Если твой create действие создает недопустимый объект, он будет повторно визуализировать new вид, который все еще ожидает @categoria быть определенным, но это не так.

Вам нужно будет определить переменную экземпляра в обоих ваших new а также create действия.

<%= f.select :categoria_id, options_for_select(@categoria, :name, :id), :required => true %>

Вы должны определить переменную экземпляра @categoria = Categoryor.all в действиях new, create, edit, update в вашем контроллере.

Где твое творческое действие? Вы определили новое действие, но не создали действие в вашем контроллере. Действие создания - это то, что спасет ваш объект.

Вы создали какой-либо categoria еще? Это единственная причина, по которой я могу думать, почему @categoria вернул бы ноль по вашему мнению.

Другие вопросы по тегам