由于这个取得下一条和取得上一条的记录其实在日常的开发当中还是会经常遇到,最常见的场景可能就是取得一篇文章的上一篇文章和下一篇文章了。其实这个在Laravel
的Eloquent
中实现还是挺容易的,不过由于Laravel
并没有直接提供给我们相应的方法,我们得使用一个小小的技巧:
取得上一篇的文章id
protected function getPrevArticleId($id)
{
return Article::where('id', '<', $id)->max('id');
}
$id就是当前文章的id
,我们通过max()
来取得比当前id
小的最大值,也就是当前id
的前一篇文章的id
。
取得下一篇的文章id
protected function getNextArticleId($id)
{
return Article::where('id', '>', $id)->min('id');
}
基本上可以说是:同理可得
。这个取得下一篇文章的id
其实就是一个相反的过程,理解万岁。
一旦我们取得上一篇和下一篇的文章id之后,我们就可以随心所欲了,比如:
$next_article = Article::find($this->getNextArticleId($article->id));
多说两句
那如果是对于一个文章的管理来说,我们其实可以这么做:
给articles
表中增加一个published_at
的字段,这里可以将published_at
字段设置为一个Carbon
对象,然后我们在前端展示的时候就可以根据published_at
来判读是否将文章展示出来。
比如说查询语句:
public function scopePublished($query)
{
$query->where('published_at','<=',Carbon::now());
}
//以上方法位于Article中,下面的查询我放在了ArticleController中
$articles = Article::latest('published_at')->published()...
View展示:
<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 < Carbon\Carbon::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>
处理文章的前一篇和后一篇的解决方案已完成。
Happy Hacking
不管是 uuid 还是乱序的,都是唯一的吧。也是可以根据 id 返回一个 collection,再从 collection 取你的 uuid 或者乱序的就可以了吧