0

リソースは 1 回だけ入れ子にする必要があることはわかっていますが、3 つの入れ子になった水域に浸る 2 つのモデルがあり、必要以上に複雑になりますが、これら 2 つのケースでそれを回避する方法がわかりません.. 。それで:

ネストは次のように機能します: group>navbar>links

リンク フォームをレンダリングする際に問題が発生しています。

- simple_form_for new_group_navbar_link_path(@group, @navbar, @link) do |f|
  %fieldset.well.pleft80.edit
    = f.input :method_name
    = f.input :text
    = f.input :button

  .form-actions
    = f.submit nil, :class => 'btn btn-primary pull-right btn-large'

navbar belongs_to groups and link belongs_to navbar

コントローラー: クラス LinksController < ApplicationController before_filter :fetch_group before_filter :fetch_navbar before_filter :fetch_link, only: [:show, :edit, :update, :destroy]

  def show
  end

  def new
    @link = Link.new
  end

  def create
    @link = @navbar.links.build(params[:link])

    if @link.save
      redirect_to @navbar, notice: 'link was successfully updated.'
     else
     render :new
    end
 end

 def edit
   @image = @link.build_image unless @link.image
 end

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

  def destroy
    @link.destroy
    redirect_to navbar_path(@navbar)
  end

  private

  def fetch_group
    @group = Group.find(params[:group_id])
  end
  def fetch_navbar
    @navbar = Navbar.find(params[:navbar_id])
  end
  def fetch_link
    @link = @navbar.links.find(params[:id])
  end
end

私が見落としている単純なものはありますか?

4

1 に答える 1

1

交換するだけ

- simple_form_for new_group_navbar_link_path(@group, @navbar, @link) do |f|

= simple_form_for new_group_navbar_link_path(@group, @navbar, @link) do |f|
于 2013-06-26T17:24:34.183 に答える