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

app/Http/Controllers/ProductsController.php

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

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

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

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 5
leo

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

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

什么叫「过滤指定字段」

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

file

file

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

5年前 评论
leo

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

5年前 评论

@leo 就是 这里的困扰,

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

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

5年前 评论
leo

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

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

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