国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 建站經驗 > 正文

Laravel 中獲取上一篇和下一篇數據

2024-04-25 20:40:03
字體:
來源:轉載
供稿:網友

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

Laravel的Eloquent ORM 怎么獲取當前記錄的下一條

然后,當時在答案里面簡單寫了一下解決方案。不過由于這個取得下一條和取得上一條的記錄其實在日常的開發當中還是會經常遇到,最常見的場景可能就是取得一篇文章的上一篇文章和下一篇文章了。其實這個在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>

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

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 陈巴尔虎旗| 石阡县| 通榆县| 安义县| 阜阳市| 馆陶县| 开鲁县| 镇平县| 手机| 辽中县| 东莞市| 尚志市| 平顺县| 偏关县| 辽阳县| 博湖县| 噶尔县| 方城县| 黎城县| 百色市| 丹江口市| 巫山县| 灌南县| 达州市| 孟州市| 石首市| 景宁| 安岳县| 吴桥县| 饶平县| 泸定县| 平南县| 都兰县| 同心县| 昌都县| 无锡市| 琼结县| 天水市| 翁源县| 清镇市| 唐海县|