繁体   English   中英

API 资源上的 Laravel 集合分页问题

[英]Laravel Collection Pagination Problem on API Resource

如果我使用 Laravel 的分页方法,下面的代码给出了Uncaught ErrorException: Trying to get property 'id' of non-object in...错误。 如果我使用all() ,它工作正常。

 $articles = Models\Article::paginate(); // Eloquent collection
 return Article::collection(collect($articles));

文章.php

class Notification extends JsonResource
{
        public function toArray($request)
        {
            return [
                'id'      => $this->resource->id,
                'title'   => $this->resource->title,
            ];
        }
    }

我还尝试创建一个 ResourceCollection 并将查询结果发送给它,但它是一样的。

Collection {#547
  #items: array:12 [
    "current_page" => 1
    "data" => array:1 [
      0 => array:10 [
        "id" => 1
        "title" => "Test"
        "body"" => "test"
      ]
    ]
    "first_page_url" => "https://localhost/api/v1/articles?page=1"
    "from" => 1
    "last_page" => 1
    "last_page_url" => "https://localhost/api/v1/articles?page=1"
    "next_page_url" => null
    "path" => "https://localhost/api/v1/articles"
    "per_page" => 15
    "prev_page_url" => null
    "to" => 1
    "total" => 1
  ]
}

为什么它返回页码,而不是完整的 object? 我想念什么? 我检查了文档,但是当我使用分页时,它似乎是由 Laravel 处理的。

我想到了。 collect助手包装查询结果是不必要的。 现在可以了。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM