rails:嵌套资源保存空记录

问题描述 投票:0回答:2

我创建了一种简单的嵌套资源形式。我无法让todo_item的子表单正确保存。当我单击“创建待办事项”按钮时,无论我在标题字段中放置什么,都会创建并保存一条空记录。

代码非常简单,父记录保存得很好。儿童记录正在显示,所以我无法弄清楚可能出现的问题。请帮忙。

我的模特:

class TodoItem < ActiveRecord::Base
  belongs_to :todo_list
end

class TodoList < ActiveRecord::Base
  has_many :todo_items, dependent: :destroy
end

我的控制器:

class TodoItemsController < ApplicationController
  before_action :set_todo_list
  before_action :set_todo_item, only: [:show, :edit, :update, :destroy]

  def new
    @todo_item = @todo_list.todo_items.new
  end

  def create
    @todo_item = @todo_list.todo_items.new

    respond_to do |format|
      if @todo_list.save
        format.html { redirect_to @todo_list, notice: 'Todo item was successfully created.' }
        format.json { render :show, status: :created, location: @todo_list }
      else
        format.html { render :new }
        format.json { render json: @todo_list.errors, status: :unprocessable_entity }
      end
    end
  end

  private

    def set_todo_item
      @todo_item = @todo_list.todo_items.find(params[:id])
    end

    def set_todo_list
      @todo_list = TodoList.find(params[:todo_list_id])
    end

    def todo_item_params
      params.require(:todo_item).permit(:title, :due_date, :description, :text, :completed)
    end

end

View.html.erb:

<h1>New Todo Item</h1>

<%= render 'form' %>

<%= link_to 'Back', @todo_list %>

_form.html.erb:

<%= form_for([@todo_list, @todo_item]) do |f| %>
 ...

  <div class="field">
    <%= f.label :title %><br>
    <%= f.text_field :title %>
  </div>
  <div class="actions">
    <%= f.submit %>
  </div>
<% end %>

enter image description here

ruby-on-rails nested-resources
2个回答
0
投票

您需要修改create方法:

def create
@todo_item = @todo_list.todo_items.create(todo_item_params)

respond_to do |format|
  if @todo_list.save
    format.html { redirect_to @todo_list, notice: 'Todo item was successfully created.' }
    format.json { render :show, status: :created, location: @todo_list }
  else
    format.html { render :new }
    format.json { render json: @todo_list.errors, status: :unprocessable_entity }
  end
end

结束


1
投票

你在这里初始化@todo_item

def create
  @todo_item = @todo_list.todo_items.new # <===== INITIALIZED HERE

  respond_to do |format|
    if @todo_list.save # <===== SAVED HERE WITHOUT EVER ASSIGNING VALUES.
      format.html { redirect_to @todo_list, notice: 'Todo item was successfully created.' }
      format.json { render :show, status: :created, location: @todo_list }
    else
      format.html { render :new }
      format.json { render json: @todo_list.errors, status: :unprocessable_entity }
    end
  end
end

但是,不要向new提供任何论据。所以,新记录没有价值。

相反,做一些更像是:

@todo_item = @todo_list.todo_items.new(todo_item_params)

也许你还应该添加一些验证,这样你就可以避免这种情况。

© www.soinside.com 2019 - 2024. All rights reserved.