2012-09-22 170 views
0

我有一个新幼儿园嵌套形式

<%= form_for @kindergarten, :html => {:multipart => true} do |f|%> 

       <%= render 'shared/error_messages', object: f.object %> 
      </br> 
       <%= f.fields_for :photos do |p| %> 
        <%= p.label 'upload photo'%> 
        <%= p.file_field :image %> 
       <% end %> 
      </br> 
       <%= render 'about_company', f: f%> 
      </br> 
       <%= render 'contact', f: f %> 
       <%= f.submit "Create my account", class: "btn btn-large btn-primary" %> 
      <%end%> 

这背后的逻辑是,1所幼儿园可以有多个照片以下形式声明。

这里是模型声明:

幼儿园

has_many :photos, limit: 7, dependent: :destroy 
accepts_nested_attributes_for :photos 

照片

attr_accessible :image, :logo, :kindergarten_id 
    belongs_to :kindergarten 
    mount_uploader :image, ImageUploader 

    validates :kindergarten_id, presence: true 
    validates :photo, presence: true 

我与这个挣扎了几个小时,现在,我不明白为什么“上传文件“按钮和标签不显示。当我说现在显示,我的意思是他们完全被忽略,不呈现在呈现的HTML。

回答

1

之前渲染的形式为新@幼儿园,你需要建立一个照片协会这个工作:

def new 
    @kindergarden = Kindergarden.new 
    @kindergarden.photos.build # provides a photo object to use in the form 
    # rest of your action 
end 

另外,如果你在表单希望多个照片领域,你可以这样做是这样的:

5.times { @kindergarden.photos.build } 
+0

现在我得到这个错误:'未定义的方法“照片”的零:NilClass' –

+1

我不能告诉你在哪里得到这个错误。您需要提供更多信息。 – rossta

+0

它只是这样的:'app/controllers/kindergartens_controller.rb:5:'new''。我也更新了控制器内的新动作,现在看起来像这样:'def new @kindergarten = Kindergarten.new @ kindergarden.photos.build end' –