【问题标题】:How do I paginate a collection or custom query into API json in Laravel?如何在 Laravel 中将集合或自定义查询分页到 API json 中?
【发布时间】:2021-12-10 14:32:59
【问题描述】:

我有一个复杂的查询,它不基于我想要为其分页输出的任何特定模型表。然而,laravel 的内置分页依赖于模型和表格。如何对集合进行分页并使输出与 laravel 内置的分页输出格式匹配?

【问题讨论】:

标签: arrays laravel-5 collections pagination paginator


【解决方案1】:

我将它保存在 app\Core\Helpers 类中,以便我可以从任何地方以 \App\Core\Helpers::makePaginatorForCollection($query_results) 的形式调用它们。最有可能使用它的地方是处理复杂查询的控制器的最后一行。

在 app/Http/Controllers/simpleExampleController.php 中

/**
 * simpleExampleController
 **/
public function myWeirdData(Request $request){
    $my_unsafe_sql = '...';//never do this!!
    $result = DB::statement(DB::raw($my_unsafe_sql));
    return \App\Core\Helpers::makePaginatorForCollection($result);
}

在 app\Core\Helpers.php 或任何你喜欢的地方自动加载。

/**
 * This will match laravel's built in Model::paginate()
 * because it uses the same underlying code.
 *
 * @param \Illuminate\Support\Collection $collection
 *
 * @return \Illuminate\Pagination\LengthAwarePaginator
 */
public static function makePaginatorForCollection(\Illuminate\Support\Collection $collection){
    $current_page = (request()->has('page')? request()->page : 1) -1;//off by 1 (make zero start)
    $per_page = (request()->has('per_page')? request()->per_page : config('api.pagination.per_page')) *1;//make numeric
    $page_data = $collection->slice($current_page * $per_page, $per_page)->all();

    return new \Illuminate\Pagination\LengthAwarePaginator(array_values($page_data), count($collection), $per_page);
}

/**
 * Copy and refactor makePaginatorForCollection()
 * if collection building is too slow.
 *
 * @param $array
 *
 * @return \Illuminate\Pagination\LengthAwarePaginator
 */
public static function makePaginatorForArray($array){
    $collection = collect($array);

    return self::makePaginatorForCollection($collection);
}

【讨论】:

    猜你喜欢
    • 2018-06-14
    • 1970-01-01
    • 2017-09-21
    • 2014-05-08
    • 1970-01-01
    • 2019-03-04
    • 2022-01-12
    • 1970-01-01
    • 2014-07-04
    相关资源
    最近更新 更多