最近始めたばかりなんですが、今ECサイト作っています。そこでデータの引き出し方がいまいちよくわからなくて質問させていただきました。
商品(prooducts)とユーザー(users)とお気に入り(favorites)とテーブルがありまして、users/showにてお気に入りに登録してある商品の一覧を表示させたいのですが、うまくできませんでした。
models/user.rb
class User < ApplicationRecord validates :password_digest,presence: true validates :email,presence: true validates :name, presence: true, uniqueness: true has_secure_password after_destroy :ensure_an_admin_remains has_many :favorites, dependent: :destroy end
models/product.rb
class Product < ApplicationRecord has_many :favorites, dependent: :destroy belongs_to :category before_destroy :ensure_not_referenced_by_any_line_item validates :title, :description, presence: true validates :price, numericality: {greater_than_or_equal_to: 0.01} validates :title, uniqueness: true end
models/favorite.rb
class Favorite < ApplicationRecord belongs_to :product belongs_to :user validates :user, presence: true validates :user_id, uniqueness:{scope: :product_id} validates :product, presence: true end
schema.rb
ActiveRecord::Schema.define(version: 20180416115630) do create_table "favorites", force: :cascade do |t| t.integer "user_id" t.integer "product_id" t.datetime "created_at", null: false t.datetime "updated_at", null: false end create_table "products", force: :cascade do |t| t.string "title" t.text "description" t.string "image_url" t.decimal "price", precision: 8, scale: 2 t.datetime "created_at", null: false t.datetime "updated_at", null: false t.string "category_id" end create_table "users", force: :cascade do |t| t.string "name" t.string "password_digest" t.datetime "created_at", null: false t.datetime "updated_at", null: false t.string "email" end end
このような感じで作っています。
実際やりたいことはusers/show.html.erbにて、ユーザーがお気に入りに追加した商品の一覧を出したいです。
@user.favorites.countでお気に入り追加した数の表示まではできたのですが何を追加したのかが出せないという感じです。
最後に、ターミナルにて@user.favoritesで出て来る表示はこのような感じです
[41] pry(main)> @user.favorites => [#<Favorite:0x0b0ebe28 id: 1, user_id: 7, product_id: 16, created_at: Sat, 07 Apr 2018 20:59:34 JST +09:00, updated_at: Sat, 07 Apr 2018 20:59:34 JST +09:00>, #<Favorite:0x0b0cdf68 id: 3, user_id: 7, product_id: 17, created_at: Sat, 07 Apr 2018 21:05:35 JST +09:00, updated_at: Sat, 07 Apr 2018 21:05:35 JST +09:00>]
以上です。ここから商品(product)の詳細を表示する記述や、そもそも間違っているなどご教授いただけると助かります。宜しくお願いしますm(._.)m
あなたの回答
tips
プレビュー