多对多模型关联 ,如果字段 过滤指定字段,怎么优雅的处理写法比较好?

app/Http/Controllers/ProductsController.php

public function favorites(Request $request)
{
    $products = $request->user()->favoriteProducts()->paginate(16);

    return view('products.favorites', ['products' => $products]);
}

多对多模型关联 ,如果字段 过滤指定字段,怎么优雅的处理写法比较好?

《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 5
leo

@gyp719 哦哦,可以把要 select 的字段放在 paginate 的第二个参数 paginate(16, ['id', 'title'])

4年前 评论
gyp719 (楼主) 4年前
leo

什么叫「过滤指定字段」

4年前 评论
gyp719 (楼主) 4年前

file

file

就是 收藏列表 只需要几个字段,没有过滤字段,将 products 的所有字段查询出来了

4年前 评论
leo

加上 ->select(['id', 'name' .....])

4年前 评论

@leo 就是 这里的困扰,

$products = $request->user()->favoriteProducts()->select(['products.id', 'title'])->paginate(16); 此时 select 失效

$products = $request->user()->favoriteProducts()->select(['products.id', 'title'])->get(); 此时 select 有效 ,但是 没有分页

4年前 评论
leo

@gyp719 哦哦,可以把要 select 的字段放在 paginate 的第二个参数 paginate(16, ['id', 'title'])

4年前 评论
gyp719 (楼主) 4年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!