溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法

發(fā)布時間:2021-06-29 10:27:53 來源:億速云 閱讀:124 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要講解了“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”吧!

首先文章的起源來與SF上面的一個問題:

Laravel的Eloquent ORM 怎么獲取當(dāng)前記錄的下一條

然后,當(dāng)時在答案里面簡單寫了一下解決方案。不過由于這個取得下一條和取得上一條的記錄其實在日常的開發(fā)當(dāng)中還是會經(jīng)常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實這個在Laravel的Eloquent中實現(xiàn)還是挺容易的,不過由于Laravel并沒有直接提供給我們相應(yīng)的方法,我們得使用一個小小的技巧:

取得上一篇的文章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');
  }

基本上可以說是:同理可得。這個取得下一篇文章的id其實就是一個相反的過程,理解萬歲。

一旦我們?nèi)〉蒙弦黄拖乱黄奈恼耰d之后,我們就可以隨心所欲了,比如:

復(fù)制代碼 代碼如下:

$next_article = Article::find($this->getNextArticleId($article->id));

多說兩句

那如果是對于一個文章的管理來說,我們其實可以這么做:

給articles表中增加一個published_at的字段,這里可以將published_at字段設(shè)置為一個Carbon對象,然后我們在前端展示的時候就可以根據(jù)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>

處理文章的前一篇和后一篇的解決方案已完成。

感謝各位的閱讀,以上就是“Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Laravel中獲取上一篇和下一篇數(shù)據(jù)的方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI