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

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

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

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

Q&A

0回答

935閲覧

データの引き出し方と表示の仕方

takeke

総合スコア60

Ruby

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

0グッド

1クリップ

投稿2018/04/17 09:05

最近始めたばかりなんですが、今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

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問