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

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

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

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Q&A

解決済

1回答

4560閲覧

laravelでいいね機能の実装

keisuke713

総合スコア25

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

0グッド

0クリップ

投稿2018/12/26 05:21

*前提
laravelでオリジナルアプリの製作をしていて、いいね機能の実装をしたいです。

・関連するテーブル
・userテーブル(ユーザー)
idカラム
nameカラム

・productテーブル(商品)
nameカラム
user_idカラム

・likeテーブル(いいね機能)
user_idカラム
proudct_idカラム

各テーブルの関係は以下のようになっています。

user.php

php

1public function products() 2 { 3 return $this->hasMany('App\Product'); 4 } 5 6 public function likes() 7 { 8 return $this->hasMany('App\Like'); 9 }

product.php

php

1public function user() 2 { 3 return $this->belongsTo('App\User'); 4 } 5 6 public function likes() 7 { 8 return $this->hasMany('App\Like'); 9 }

like.php

php

1public function user() 2 { 3 return $this->belongsTo('App\User'); 4 } 5 6 public function product() 7 { 8 return $this->belongsTo('App\Product'); 9 }

*実現したいこと
ログインしているユーザーが商品をいいねしているときは『いいねを解除する』、いいねしていないときは『いいねする』と表示させたいです。

*つまづいていること
『いいね済み』、『いいねする』の表示がうまくいかず、デフォルトが『いいねを解除する』になっています。

*該当するコード

blade.php

php

1@if($product->likes()->where('user_id', Auth::user()->id)) 2 <a href="{{ action('Admin\MercariController@release', ['id' => $product->id]) }}" class="btn btn-primary">いいねを解除する</a> 3 @else 4 <a href="{{ action('Admin\MercariController@like', ['id' => $product->id]) }}" class="btn btn-primary">いいねする</a> 5 @endif

controller.php

public function like(Request $request) { $like = new Like; $like->user_id = Auth::user()->id; $like->product_id = $request->id; $product = Product::find($request->id); $user = User::find($product->user_id); $like->save(); return view('admin.mercari.top'); }

以上です。

よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

これの結果は何が出るのでしょうか。
$product->likes()->where('user_id', Auth::user()->id)

単にtrue/falseで判断してますので「select文が成功するかどうか」になってますよね。
結果ヒットしなくてもtrueになります。
レコードが存在するかどうか(件数・カウント)で判断すべきではないでしょうか。

投稿2018/12/26 05:56

編集2018/12/26 05:57
m.ts10806

総合スコア80850

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

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

keisuke713

2018/12/27 04:26

countを使ったらできました。 ありがとうございました。
m.ts10806

2018/12/27 04:50

解決されたようで何よりです。 機能を使う場合は「返却値は何か」は必ず確認して、それがどのような影響を与えるか考えてから使ってくださいね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問