Laravel 中获取上一篇和下一篇数据
《Laravel 中获取上一篇和下一篇数据》要点: 首先文章的起源来与SF上面的一个问题:PHP编程 Laravel的Eloquent ORM 怎么获取当前记录的下一条PHP编程 然后,当时在答案里面简单写了一下解决方案.不过由于这个取得下一条和取得上一条的记录其实在日常的开发当中还是会经常遇到,最常见的场景可能就是取得一篇文章的上一篇文章和下一篇文章了.其实这个在Laravel的Eloquent中实现还是挺容易的,不过由于Laravel并没有直接提供给我们相应的办法,我们得使用一个小小的技巧:PHP编程 取得上一篇的文章idPHP编程 protected function getPrevArticleId($id) { return Article::where('id','<',$id)->max('id'); } $id便是当前文章的id,我们通过max()来取得比当前id小的最大值,也便是当前id的前一篇文章的id.PHP编程 取得上一篇的文章idPHP编程 protected function getNextArticleId($id) { return Article::where('id','>',$id)->min('id'); } 基本上可以说是:同理可得.这个取得下一篇文章的id其实便是一个相反的过程,理解万岁.PHP编程 一旦我们取得上一篇和下一篇的文章id之后,我们就可以随心所欲了,好比:PHP编程
代码如下:
$next_article = Article::find($this->getNextArticleId($article->id));
多说两句PHP编程 那如果是对于一个文章的管理来说,我们其实可以这么做:PHP编程 给articles表中增加一个published_at的字段,这里可以将published_at字段设置为一个Carbon对象,然后我们在前端展示的时候就可以根据published_at来判读是否将文章展示出来.PHP编程 好比说查询语句:PHP编程 public function scopePublished($query) { $query->where('published_at','<=',Carbon::now()); } //以上办法位于Article中,下面的查询我放在了ArticleController中PHP编程 $articles = Article::latest('published_at')->published()... View展示:PHP编程 <li class="previous"> @if($prev_article) <a href="/post/{{ $prev_article->slug }}" rel="prev"><i class="fa fa-chevron-left"></i><strong>上一篇</strong><span> {{ $prev_article->title }}</span> </a> @endif </li> <li class="next"> @if($next_article && $next_article->published_at < CarbonCarbon::now()) <a href="/post/{{ $next_article->slug }}" rel="next"><i class="fa fa-chevron-right"></i><strong>下一篇</strong> <span> {{ $next_article->title }}</span></a> @endif </li> 处理文章的前一篇和后一篇的办理方案已完成.PHP编程 以上所述便是本文的全部内容了,希望大家能够喜欢.PHP编程 欢迎参与《Laravel 中获取上一篇和下一篇数据》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |