下面的函数GET的用户ID并从用户的手表列表中获取项目。有没有办法可以将以下逻辑添加到视图中?评论的行具有我试图将它传递给的视图。

public function getWatchList() {

    $user = User::find(Auth::user()->id);
    $item = WatchList::where('user_id', '=', $user->id)->get();

     foreach ($item as $i) {
        $items = Catagory::where('id', '=', $i->item_id)->get();

            foreach ($items as $item) {
                echo $item->id;
            }
     }

    // return View::make('account.watchlist')
    //     ->with('items', $items);
}
.

有帮助吗?

解决方案

// don't need that, unnecessary db call, twice..
// $user = User::find(Auth::user()->id);

// you can do this:
$categoriesIds = WatchList::where('user_id', '=', Auth::id())->lists('item_id');

// then
$categories = Category::whereIn('id', $categoriesIds)->get();

return View::make('account.watchlist')->with('categories', $categories);
.

查看模板(account/watchlist.blade.php):

@foreach ($categories as $category)
   {{ $category->id }}
@endforeach
.

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top