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

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

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

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Laravel

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

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

1回答

2393閲覧

LaravelからVue側に渡したDBのレコードの平均値を表示たい

chocomint20

総合スコア1

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Laravel

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

PHP

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2020/08/29 11:08

編集2020/08/31 10:10

LaravelからVue側に渡したDBのレコードの平均値を表示したい

LaravelのControllerからDBに保存されたデータをVueのコンポーネントに渡しています。
データは商品に紐付けられたユーザー情報とカテゴリー、レビューの情報です。
ProductShow.vueのファイルでその情報を展開して表示しているのですが、「総合評価」という項目に渡ってきたデータの評価点(この商品のidとリレーションしたreviewesテーブルのpointというカラムの値の平均値)を表示したいと思っているのですが、なかなか実装出来ずに困っています。
下記にコードを記載してありますので、アドバイスいただけたらと思います。当サイト初心者ですのでもっと載せた方がいいコードなどありましたらご指摘ください。

web.php

Route::get('/products/{id}', 'ProductsController@show')->name('products.show');

ProductsController.php

// 商品詳細画面表示 public function show($id) { $product = Product::with(['user', 'category', 'reviews'])->find($id); return view('products.show', [ 'product' => $product, ]); }

show.blade.php

<div id="app"> <product-show :product="{{$product}}"></product-show> </div>

ProductShow.vue

<template> <div class="l-form p-form"> <div class="l-itemdetail p-itemdetail"> <div class="l-itemdetail__title p-itemdetail__title"> <h1>{{ product.title }}</h1> </div> <div class="l-itemdetail__img p-itemdetail__img"> <template v-if="(product.pic)"> <img :src="'/storage' + product.pic" alt=""/> </template> <template v-else> <img src="/images/product-noimg.png" alt="" /> </template> </div> <div class="l-btn-conteiner"> <button type="submit" class="p-btn btn-favorite"><i class="far fa-heart icon icon-heart"></i>気になる</button> </div> <table class="l-itemdetail__table p-itemdetail__table"> <tbody> <tr> <th>出品者</th> <td>{{ product.user.name }}</td> </tr> <tr> <th>カテゴリー</th> <td>{{ product.category.name }}</td> </tr> <tr> <th>概要</th> <td>{{ product.overview }}</td> </tr> <tr> <th>総合評価</th> <template v-for="review in product.reviews"> <td>{{ review }}</td> <!-- ここに平均点を表示したい --> </template> </tr> </tbody> </table> </div> </div> </template> <script> export default { props: { product: Object, }, mounted() { console.log('Component mounted.') } } </script>

Product.php

<?php namespace App; use Illuminate\Database\Eloquent\Model; class Product extends Model { protected $fillable = [ 'pic','title', 'overview', 'category_id', 'contents', 'price', 'user_id', 'delete_flg', ]; public function category() { return $this->belongsTo('App\Category'); } public function reviews() { return $this->hasMany('App\Review'); } public function user() { return $this->belongsTo('App\User'); } }

Review.php

<?php namespace App; use Illuminate\Database\Eloquent\Model; class Review extends Model { public function product() { return $this->belongsTo('App\Product'); } public function user() { return $this->belongsTo('App\User'); } }

User.php

<?php namespace App; use Illuminate\Notifications\Notifiable; use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Foundation\Auth\User as Authenticatable; class User extends Authenticatable { use Notifiable; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'pic', 'name', 'introduction', 'email', 'password', 'delete_flg', ]; /** * The attributes that should be hidden for arrays. * * @var array */ protected $hidden = [ 'password', 'remember_token', ]; /** * The attributes that should be cast to native types. * * @var array */ protected $casts = [ 'email_verified_at' => 'datetime', ]; public function reviews() { return $this->hasMany('App\Review'); } public function products() { return $this->hasMany('App\Product'); } }

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

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

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

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

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

phper.k

2020/08/31 02:19

Productモデルの実装を確認しないと回答できないです。
chocomint20

2020/08/31 10:11

すみません、ご指摘のModelを追記しました。
guest

回答1

0

ベストアンサー

php

1class Product extends Model 2{ 3 public function getReviewAvarageAttribute() 4 { 5 return round($this->reviews->pluck('point')->avg(), 0); 6 } 7}

こんな感じの、アクセサを定義しておくのが一番楽だと思います。

投稿2020/08/31 10:34

phper.k

総合スコア3923

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

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

chocomint20

2020/08/31 12:27

ありがとうございます。ご教授して頂いた内容で希望通りの機能を実装することができました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問