這篇文章主要講解了“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”吧!
成都創(chuàng)新互聯(lián)公司基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺為眾多戶提供內(nèi)江服務(wù)器托管 四川大帶寬租用 成都機(jī)柜租用 成都服務(wù)器租用。首先文章的起源來與SF上面的一個(gè)問題:
Laravel的Eloquent ORM 怎么獲取當(dāng)前記錄的下一條
然后,當(dāng)時(shí)在答案里面簡單寫了一下解決方案。不過由于這個(gè)取得下一條和取得上一條的記錄其實(shí)在日常的開發(fā)當(dāng)中還是會(huì)經(jīng)常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實(shí)這個(gè)在Laravel的Eloquent中實(shí)現(xiàn)還是挺容易的,不過由于Laravel并沒有直接提供給我們相應(yīng)的方法,我們得使用一個(gè)小小的技巧:
取得上一篇的文章id
protected function getPrevArticleId($id) { return Article::where('id', '<', $id)->max('id'); }
$id就是當(dāng)前文章的id,我們通過max()來取得比當(dāng)前id小的較大值,也就是當(dāng)前id的前一篇文章的id。
取得上一篇的文章id
protected function getNextArticleId($id) { return Article::where('id', '>', $id)->min('id'); }
基本上可以說是:同理可得。這個(gè)取得下一篇文章的id其實(shí)就是一個(gè)相反的過程,理解萬歲。
一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,比如:
復(fù)制代碼 代碼如下:
$next_article = Article::find($this->getNextArticleId($article->id));
多說兩句
那如果是對于一個(gè)文章的管理來說,我們其實(shí)可以這么做:
給articles表中增加一個(gè)published_at的字段,這里可以將published_at字段設(shè)置為一個(gè)Carbon對象,然后我們在前端展示的時(shí)候就可以根據(jù)published_at來判讀是否將文章展示出來。
比如說查詢語句:
public function scopePublished($query) { $query->where('published_at','<=',Carbon::now()); }
//以上方法位于Article中,下面的查詢我放在了ArticleController中
$articles = Article::latest('published_at')->published()...
View展示:
處理文章的前一篇和后一篇的解決方案已完成。
感謝各位的閱讀,以上就是“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!