解决Laravel5.5下的toArray问题

2020-10-20 14:47:28 浏览数 (1)

作为一个有轻度强迫症且受ThinkPHP影响较深的PHP码农,总觉得Laravel5.5的DB::xxoo- get()- toArray()之后竟然还没得到我想要的ThinkPHP中的select()出来的数组,于是决定做一下修改。

PS:出于尽量不影响原有框架的考虑,我是新建了一个方法叫getList来暂代toArray那不知所谓的返回结果,在没有找到更好的解决办法之前,暂时这么用着,总体感觉,get()- getList()仍觉得略丑。。。。

具体修改如下:

1、在/vendor/laravel/framework/src/Illuminate/Support/Collection.php的toAarray方法下,增加一个getList方法

代码语言:javascript复制
public function getList(){
  return array_map('get_object_vars', $this- items);
 }

2、然后就可以这样来查列表了

代码语言:javascript复制
$goods_category_list=DB::table('lara_goods_category')- select('goods_category_id','goods_category_name','goods_category_shortname')- where('goods_category_show', '=', 1)- offset(0)- limit(5)- orderBy('goods_category_sort', 'asc')- get()- getList();

3、返回的正是我所想要的数组,如下图:

以上这篇解决Laravel5.5下的toArray问题就是小编分享给大家的全部内容了,希望能给大家一个参考。

0 人点赞