Laravel 中获取上一篇和下一篇数据


Posted in PHP onJuly 27, 2015

首先文章的起源来与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>

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

以上所述就是本文的全部内容了,希望大家能够喜欢。

PHP 相关文章推荐
用PHP读注册表
Oct 09 PHP
怎么样可以把 phpinfo()屏蔽掉?
Nov 24 PHP
PHP中MD5函数使用实例代码
Jun 07 PHP
PHPWind与Discuz截取字符函数substrs与cutstr性能比较
Dec 05 PHP
解析csv数据导入mysql的方法
Jul 01 PHP
php输入流php://input使用示例(php发送图片流到服务器)
Dec 25 PHP
Laravel 4 初级教程之Pages、表单验证
Oct 30 PHP
php支付宝手机网页支付类实例
Mar 04 PHP
PHP排序算法类实例
Jun 17 PHP
php生成gif动画的方法
Nov 05 PHP
解决form中action属性后面?传递参数 获取不到的问题
Jul 21 PHP
php 策略模式原理与应用深入理解
Sep 25 PHP
php实现将Session写入数据库
Jul 26 #PHP
php检测文本的编码
Jul 26 #PHP
PHP中COOKIES使用示例
Jul 26 #PHP
PHP实现简单数字分页效果
Jul 26 #PHP
FastCGI 进程意外退出造成500错误
Jul 26 #PHP
php实现QQ空间获取当前用户的用户名并生成图片
Jul 25 #PHP
使用纯php代码实现页面伪静态的方法
Jul 25 #PHP
You might like
PHP+MySql+jQuery实现的&quot;顶&quot;和&quot;踩&quot;投票功能
2016/05/21 PHP
IE8下String的Trim()方法失效的解决方法
2013/11/08 Javascript
jQuery改变form表单的action,并进行提交的实现代码
2016/05/25 Javascript
利用javascript实现的三种图片放大镜效果实例(附源码)
2017/01/23 Javascript
JavaScript Uploadify文件上传实例
2017/02/28 Javascript
微信小程序 数据遍历的实现
2017/04/05 Javascript
集合Bootstrap自定义confirm提示效果
2017/09/19 Javascript
ES6中的class是如何实现的(附Babel编译的ES5代码详解)
2019/05/17 Javascript
20个必会的JavaScript面试题(小结)
2019/07/02 Javascript
node.js中npm包管理工具用法分析
2020/02/14 Javascript
JavaScript鼠标拖拽事件详解
2020/04/03 Javascript
[56:14]Fnatic vs OG 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
浅谈python为什么不需要三目运算符和switch
2016/06/17 Python
python3实现网络爬虫之BeautifulSoup使用详解
2018/12/19 Python
python爬虫解决验证码的思路及示例
2019/08/01 Python
对Pytorch中Tensor的各种池化操作解析
2020/01/03 Python
如何基于python实现归一化处理
2020/01/20 Python
python3.x中安装web.py步骤方法
2020/06/23 Python
Python利用命名空间解析XML文档
2020/08/10 Python
浅析border-radius如何兼容IE
2016/04/19 HTML / CSS
世界首屈一指的在线男士内衣权威:HisRoom
2017/08/05 全球购物
美国著名手表网站:Timepiece
2017/11/15 全球购物
美国购买韩国护肤和美容产品网站:Althea Korea
2020/11/16 全球购物
零件设计自荐信范文
2013/11/27 职场文书
项目专员岗位职责
2013/12/04 职场文书
总裁秘书岗位职责
2013/12/04 职场文书
事业单位请假制度
2014/01/13 职场文书
白血病募捐倡议书
2014/05/14 职场文书
师范大学生求职信
2014/06/13 职场文书
市贸粮局召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
信访维稳工作汇报
2014/10/27 职场文书
结婚当天新郎保证书
2015/05/08 职场文书
女方家长婚礼答谢词
2015/09/29 职场文书
高二化学教学反思
2016/02/22 职场文书
如何利用pygame实现打飞机小游戏
2021/05/30 Python
Win10开机修复磁盘错误怎么跳过?Win10关闭开机磁盘检查的方法
2022/09/23 数码科技