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

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

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

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Q&A

解決済

1回答

655閲覧

Laravelの投稿アプリで良いねした人の数をカウントする

Rint

総合スコア14

Laravel

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

0グッド

0クリップ

投稿2019/06/10 15:20

不明点

LaravelにてSNSアプリを制作中です。投稿一覧ページの各投稿に「良いね」した人の数を表示したいのですが、
取得方法が分からないためアドバイスいただきたいです。

コントローラにて複数の投稿の配列をビューに渡し、bladeファイルのビューで@foreachで展開しています。
tinker上では$card->good_users()->where('good', 'good')->count();で取得自体はできましたが、
アプリ内で一つ一つの投稿のカウントをどこで取得するのか?混乱しています。

※前提:Laravel 5.5

###テーブル構成(関連するもののみ記載)
〇Userテーブル
・id
・name
〇Cardテーブル(投稿)
・id
・conetnt
・audience_selector(公開設定)
〇Good中間テーブル(良いね機能)
・user_id
・card_id
・good(good/badの二択)

現在のコード

Card.php

php

1<?php 2namespace App; 3use Illuminate\Database\Eloquent\Model; 4 5class Card extends Model 6{ 7 protected $fillable = ['user_id', 'content', 'audience_selector']; 8 9 public function user() 10 { 11 return $this->belongsTo(User::class); 12 } 13 public function good_users() 14 { 15 return $this->belongsToMany(User::class, 'good', 'card_id', 'user_id')->withTimestamps(); 16 } 17} 18

CardController.php

php

1 public function index() 2 { 3 $cards = Card::where('audience_selector', 'like', 'public')->orderBy('created_at', 'desc')->paginate(20); 4 5 $data = [ 6 'cards' => $cards, 7 ]; 8 9 return view('welcome', $data); 10 }

welcome.blade.php

php

1@extends('commons.app') 2 3@section('content') 4<ul class="list-unstyled"> 5 @foreach ($cards as $card) 6 <li class="media"> 7 <div class="media-body"> 8 <div class="d-flex justify-content-between"> 9 <div>{!! link_to_route('users.show', $card->user->name, ['id' => $card->user->id]) !!}</div> 10 </div> 11 <div> 12 <p class="card-text">{!! nl2br(e($card->content)) !!}</p> 13 </div> 14 <div class="d-flex justify-content-between flex-row"> 15 <div class="d-flex flex-row"> 16 @include('good.good_button', ['card' => $card]) 17 </div> 18 </div> 19 </div> 20 </li> 21 @endforeach 22</ul> 23{{ $cards->render('pagination::bootstrap-4') }} 24 25@endsection

good_button.blade.php

php

1@if (Auth::check()) 2 @if (Auth::user()->pressed_good($card->id)) 3 <div class="mr-2"> 4 {{--「良いね」した場合は良いね取り消しボタン--}} 5 {!! Form::open(['route' => ['user.cancel_good', $card->id], 'method' => 'delete']) !!} 6 <button style="cursor:pointer"><i class='fas fa-thumbs-up'></i></button> 7 {!! Form::close() !!} 8 {{--ここに良いねした人のカウントを表示したい--}} 9 </div> 10 11{{--以下省略--}}

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

一つ一つの投稿のカウントをどこで取得するのか?

Cardテーブル取得時にCard中間テーブルをLeft Joinしてgoodのみ絞り込み、Card中間テーブルはcountだけとれば良いと思います。
goodとbad両方取りたければ中間テーブルは別個に、要は2度Joinしてください。

Laravelの組み方前提ではなく、まずは直接SQL叩くつもりでSQL作ってみてください。

投稿2019/06/10 22:22

m.ts10806

総合スコア80850

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

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

Rint

2019/06/11 13:58

おかげさまで解決しました!ご親切にありがとうございました。
m.ts10806

2019/06/11 21:12

ヒントになったようで何よりです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問