前提・実現したいこと
こんばんわ、laravelの初学者です。初歩的な質問で申し訳ありません。
Tweet風のappを開発中ですがviewにDBに保存されたレコードを
@foreach文で出現させる際にエラーが発生しました。
発生している問題・エラーメッセージ
Undefined variable: names (View: /Applications/MAMP/htdocs/Online-Reviews/resources/views/shops/shop_show.blade.php)
該当のソースコード
//OnlineReviewsController.php <?php namespace App\Http\Controllers; use App\Models\OnlineReviews; use Illuminate\Http\Request; use App\Models\User; use Illuminate\Support\Facades\DB;//クエリビルダでDBに保存されているものを表示させる。 class OnlineReviewsController extends Controller { /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index() //こちらが問題の箇所です。 { $names = DB::table('users') ->select('name') ->get(); $reviews =DB::table('online_reviews') ->select('title','text') ->get(); return view('shops.shop_show',compact('names','reviews')); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $review = new OnlineReviews; $review->user_id = $request->user()->id; $review->title = $request->input('title'); $review->text = $request->input('text'); // dd($title,$text); $review->save(); return redirect()->route('shops.shop_list') ; } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function show($id) { $review = OnlineReviews::find($id); return view('online_reviews.show',compact('review')); }
shop_show.blade.php <!DOCTYPE html> <html lang="ja"> <head> <meta charset="utf-8"> <title>トップページ</title> <link rel="stylesheet" href="{{ asset('css/OnlineReviews/common.css') }}"> <link rel="stylesheet" href="{{ asset('css/Shops/shop_list.css') }}"> </head> <body> <div class="wrapper"> <header> @component('components.shop_header') @slot('header') @endslot @endcomponent </header> <div class="list-box"> <div class="list-container"> <div class="hospital-name">A病院</div> <div class="address-name">大阪府大阪市</div> </div> </div> <div class="posted-table"> @foreach ($names as $name)//こちらが問題箇所です <p class="title-form"> <p class="title">投稿者 {{ $name->name}} </p> </p> @endforeach @foreach ($reviews as $review) <p class="title-form"> <p class="title">タイトル {{ $review->title}} </p> </p> <p class="title-form"> <p class="title">投稿内容 {{ $review->text}} </p> </p> @endforeach </div>
//ShopController.php <?php namespace App\Http\Controllers; use Illuminate\Http\Request; class ShopController extends Controller { public function index() { //viewを表示 return view('shops.index'); } public function show() //{id}は未定 { return view('shops.shop_show'); } }
//web.php <?php Route::get('/', function () { return view('welcome'); }); //ログイン機能 Auth::routes(); Route::get('/home', 'HomeController@index')->name('home'); //OnlineReviewsのルーティングと // ログインしないとページに遷移できないようにmiddlewareを記述 Route::group(['prefix' => 'online_reviews','middleware' => 'auth'], function(){ Route::get('index','OnlineReviewsController@index')->name('online_reviews.index'); // 投稿一覧表 Route::get('create','OnlineReviewsController@create')->name('online_reviews.create');//投稿ページの表示 Route::post('store','OnlineReviewsController@store')->name('online_reviews.store');//投稿を保存するルーティング Route::get('show/{id}','OnlineReviewsController@show')->name('online_reviews.show');//投稿の詳細を確認するルーティング }); //shopのルーティング Route::group(['prefix' => 'shop'],function(){ Route::get('index','ShopController@index')->name('shop.list'); Route::get('show','ShopController@show')->name('shop.show');//お店の詳細を確認する });
試したこと
コントローラーとviewに使用される$reviewsと$namesの変数の受け渡しの確認。compactでそれを@foreach文で呼び出しを確認しました。また、こちらのURLでリレーションが問題ありと書いてありました。念の為、リレーションを確認しましたが問題はないと思います。他に間違いがあればご教授のほどよろしくお願い申し上げます。
User.php(モデル) <?php namespace App\Models; use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; class User extends Authenticatable { use Notifiable; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'name','name_kana','email','password', 'gender','age','birthday','postal_code','address','phone', 'created_at','updated_at','title','text', ]; public function reviews() { return $this->hasMany('App\Models\OnlineReviews')->latest(); //こちらのリレーションを確認 } /** * 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', ]; }
<?php namespace App\Models; use Illuminate\Database\Eloquent\Model; class OnlineReviews extends Model { protected $fillable = [ 'title','text', ]; public function User() { return $this->belongsTo('App\Models\User');//こちらのリレーションを確認 } }
補足情報(FW/ツールのバージョンなど)
laravel6.20
になります。
回答1件
あなたの回答
tips
プレビュー