1

ユーザーがファイルを指定しない限り (一種の) 機能する、ネストされた simple_form に Carrierwave 画像をアップロードしています。ユーザーがアップロードする「新しい」画像を指定しない場合、古い画像は削除されず、ファイルのない空白のレコードが作成されるようにする方法がよくわかりません。

私がやっている(おそらく奇妙な)ことの1つは、常にログインした@userをuser#editアクションに送信し、存在しない場合は@user.pictureを作成することです。これが私の悪い設計の場所だと考えています。

    # user.rb
    class User < ActiveRecord::Base
    [...]

      has_one :picture, :dependent => :destroy
      accepts_nested_attributes_for :picture

    [...]
    end

    # picture.rb
    class Picture < ActiveRecord::Base
      attr_accessible :image, :remove_image
      belongs_to :user
      mount_uploader :image, ImageUploader
    end

    # users_controller.rb
    def edit
      if @user.picture.nil?
        @user.build_picture
      end
    end

    #_form.html.erb
    <%= simple_form_for @user, :html => {:multipart => true} do |f| %>
      <%= render "shared/error_messages", :target => @user %>  
      <h2>Picture</h2>
      <%= f.simple_fields_for :picture do |pic| %>
        <% if @user.picture.image? %>
          <%= image_tag @user.picture.image_url(:thumb).to_s %>     
          <%= pic.input :remove_image, :label => "Remove", :as => :boolean %>
        <% end %>
        <%= pic.input :image, :as => :file, :label => "Picture" %>
        <%= pic.input :image_cache, :as => :hidden %>
      <% end %>
      <br/>
    #rest of form here
    <% end %>
4

3 に答える 3

2

私は、reject_ifオプションをaccepts_nested_attributeに追加することで解決した同じ問題を抱えていたと思います。あなたの例では、次のようなことができます

class User < ActiveRecord::Base
[...]

  has_one :picture, :dependent => :destroy
  accepts_nested_attributes_for :picture,
    :reject_if => lambda { |p| p.image.blank? }

[...]
end
于 2012-02-28T21:08:45.590 に答える
0

build_* を使用すると、オブジェクトに外部キーが設定されます。( Picture.new(:user_id => id) と言うのに似ています)

これを試して

# users_controller.rb
def edit
  if @user.picture.nil?
    @user.picture = Picture.new
  end
end
于 2011-11-09T14:25:28.323 に答える
0

今日、私は同じ問題を抱えていました。私はこれを次のように解決しました:

  accepts_nested_attributes_for :photos,
    :reject_if => :all_blank
于 2012-03-10T16:56:02.493 に答える