リソースは 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
私が見落としている単純なものはありますか?