質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

1回答

730閲覧

画像を同時に複数保存させたい

ren0826nosuke

総合スコア34

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2020/05/14 01:58

解決したいこと

画像を同時に複数保存したい。

現状

現在、フリマアプリを実装中です。
商品出品時に画像を投稿できる様にしているのですが、1枚しか保存されない状況です。
選択画面では複数の画像を選択できるが、create処理を実行すると最初の1枚しか保存されていません。

試したこと

:multiple => true をfile_fieldのオプションで追加したが効果なし。

記述コード

new.html.haml

省略 .new_page_main__index = form_with model: @product, local: true do |form| .new_page_main__photo %span.label_title 出品画像 %span.required 必須 %p.upload_limit 最大10枚までアップロードできます #image-box-1 .item-num-0#image-box__container %div.photo_space ドラッグ&ドロップまたはクリックしてファイルをダウンロード .file__box = form.fields_for :product_photos do |m| = m.label :photo, class: "form-image" do = m.file_field :photo, :multiple => true, type: 'file', id:"img-file" %label{for: "img-file"} %i.fas.fa-camera 省略

products_controller.rb

def new @product = Product.new @product.product_photos.build end def create product = Product.new(product_params) if product.save redirect_to root_path, notice: '出品しました。' else render :new end end private def product_params params.require(:product).permit( :name, :explanation, :category_id, :status, :bear, :brand, :days, :price, product_photos_attributes: {photo: []}).merge(exhibitor_user_id: current_user.id) end end

product_photo.rb

class ProductPhoto < ApplicationRecord belongs_to :product, optional: true mount_uploaders :photo, ImgNameUploader end

product.rb

class Product < ApplicationRecord 省略 belongs_to :exhibitor_user ,class_name: "User" belongs_to :buyer_user ,class_name: "User", optional: true accepts_nested_attributes_for :product_photos, allow_destroy: true 省略 end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

解決

以下の記述にすることで解決できました。

#image-box #previews - if @product.persisted? - @product.photos.each_with_index do |photo, i| = image_tag product.photo.url, data: { index: i }, width: "100", height: '100' = form.fields_for :product_photos do |image| .js-file_group{"data-index" => image.index} = image.file_field :photo, class: 'js-file' %br %span.js-remove 削除 - if @product.persisted? = image.check_box :_destroy, data:{ index: image.index }, class: 'hidden-destroy' - if @product.persisted? .js-file_group{"data-index" => @product.photos.count} = file_field_tag :photo, name: "product[product_photos_attributes][#{@product.photos.count}][photo]", class: 'js-file' .js-remove 削除

投稿2020/05/19 04:38

ren0826nosuke

総合スコア34

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問