《PHP教程:Laravel 中獲取上一篇和下一篇數(shù)據(jù)》要點:
本文介紹了PHP教程:Laravel 中獲取上一篇和下一篇數(shù)據(jù),希望對您有用。如果有疑問,可以聯(lián)系我們。
首先文章的起源來與SF上面的一個問題:PHP編程
Laravel的Eloquent ORM 怎么獲取當前記錄的下一條PHP編程
然后,當時在答案里面簡單寫了一下解決方案.不過由于這個取得下一條和取得上一條的記錄其實在日常的開發(fā)當中還是會經(jīng)常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了.其實這個在Laravel的Eloquent中實現(xiàn)還是挺容易的,不過由于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編程
一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,好比:PHP編程
多說兩句PHP編程
那如果是對于一個文章的管理來說,我們其實可以這么做:PHP編程
給articles表中增加一個published_at的字段,這里可以將published_at字段設置為一個Carbon對象,然后我們在前端展示的時候就可以根據(jù)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 < 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>
處理文章的前一篇和后一篇的辦理方案已完成.PHP編程
以上所述便是本文的全部內(nèi)容了,希望大家能夠喜歡.PHP編程
歡迎參與《PHP教程:Laravel 中獲取上一篇和下一篇數(shù)據(jù)》討論,分享您的想法,維易PHP學院為您提供專業(yè)教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/9415.html