Laravel框架分页实现方法分析


Posted in PHP onJune 12, 2018

本文实例讲述了Laravel框架分页实现方法。分享给大家供大家参考,具体如下:

Laravel使用的过程中,有些功能把前端页面的表达“写死了”,比如分页的翻页按钮!

当然你会说Laravel的Bootstrap样式也很好看啊,但是实际项目中,翻页按钮常常需要满足的客户的需要,特别在开发一款支持手机适配的Web APP,更是需要使用自定义的样式。

所以,学习一样东西不能一知半解,而是究其原理。

先来看看Laravel是怎么分页的,生成分页按钮的代码究竟写在了哪里?

Laravel目录\vendor\laravel\framework\src\Illuminate\Pagination

先理一下类的继承关系

PresenterContract(父类)
BootstrapThreePresenter(子类)<-SimpleBootstrapThreePresenter
BootstrapFourPresenter(子类)<-SimpleBootstrapFourPresenter

从作者对类的命名上看,必有区别,我们从代码上研究

BootstrapThreePresenter.php和BootstrapFourPresenter.php主要区别在下列函数

BootstrapThreePresenter.php代码:

/**
* Get HTML wrapper for an available page link.
*
* @param string $url
* @param int $page
* @param string|null $rel
* @return string
*/
protected function getAvailablePageWrapper($url, $page, $rel = null)
{
    $rel = is_null($rel) ? '' : ' rel="'.$rel.'"';
    return '<li><a href="'.htmlentities($url).'" rel="external nofollow" rel="external nofollow" '.$rel.'>'.$page.'</a></li>';
}
/**
* Get HTML wrapper for disabled text.
*
* @param string $text
* @return string
*/
protected function getDisabledTextWrapper($text)
{
    return '<li class="disabled"><span>'.$text.'</span></li>';
}
/**
* Get HTML wrapper for active text.
*
* @param string $text
* @return string
*/
protected function getActivePageWrapper($text)
{
    return '<li class="active"><span>'.$text.'</span></li>';
}

BootstrapFourPresenter.php代码:

/**
* Get HTML wrapper for an available page link.
*
* @param string $url
* @param int $page
* @param string|null $rel
* @return string
*/
protected function getAvailablePageWrapper($url, $page, $rel = null)
{
    $rel = is_null($rel) ? '' : ' rel="'.$rel.'"';
    return '<li class="page-item"><a class="page-link" href="'.htmlentities($url).'" rel="external nofollow" rel="external nofollow" '.$rel.'>'.$page.'</a></li>';
}
/**
* Get HTML wrapper for disabled text.
*
* @param string $text
* @return string
*/
protected function getDisabledTextWrapper($text)
{
    return '<li class="page-item disabled"><a class="page-link">'.$text.'</a></li>';
}
/**
* Get HTML wrapper for active text.
*
* @param string $text
* @return string
*/
protected function getActivePageWrapper($text)
{
    return '<li class="page-item active"><a class="page-link">'.$text.'</a></li>';
}

我们发现最大的区别在ThreePresenter几乎是“裸”HTML标签,而FourPresenter生成的是带class的HTML标签。

无论是ThreePresenter还是FourPresenter,他们都有一个相同实现的render()函数

/**
* Convert the URL window into Bootstrap HTML.
*
* @return \Illuminate\Support\HtmlString
*/
public function render()
{
    if ($this->hasPages()) {
      return new HtmlString(sprintf(
        '<ul class="pagination">%s %s %s</ul>',
        $this->getPreviousButton(),
        $this->getLinks(),
        $this->getNextButton()
      ));
    }
    return '';
}

细心的读者已经发觉,还有两个继承类,分别是SimpleThreePresenter和SimpleFourPresenter,既然是Simple(简单),区别就在他们的render()函数

/**
* Convert the URL window into Bootstrap HTML.
*
* @return \Illuminate\Support\HtmlString
*/
public function render()
{
    if ($this->hasPages()) {
      return new HtmlString(sprintf(
        '<ul class="pager">%s %s</ul>',
        $this->getPreviousButton(),
        $this->getNextButton()
      ));
    }
    return '';
}

也就是说,SimpleThreePresenter和SimpleFourPresenter生成的分页按钮是没有“页码”的,只有“上一页”和“下一页”按钮。

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

PHP 相关文章推荐
set_include_path和get_include_path使用及注意事项
Feb 02 PHP
php生成二维码的几种方式整理及使用实例
Jun 03 PHP
php中$_POST与php://input的区别实例分析
Jan 07 PHP
php截取字符串函数分享
Feb 02 PHP
使用URL传输SESSION信息
Jul 14 PHP
php设计模式之委托模式
Feb 13 PHP
Yii2实现让关联字段支持搜索功能的方法
Aug 10 PHP
PHP实现查询手机归属地的方法详解
Apr 28 PHP
详解如何在云服务器上部署Laravel
Jun 30 PHP
thinkPHP+LayUI 流加载实现功能
Sep 27 PHP
laravel实现图片上传预览,及编辑时可更换图片,并实时变化的例子
Nov 14 PHP
PHP如何通过带尾指针的链表实现'队列'
Oct 22 PHP
php 可变函数使用小结
Jun 12 #PHP
PHP程序员学习使用Swoole的理由
Jun 24 #PHP
PHP实现的装箱算法示例
Jun 23 #PHP
PHP基于curl模拟post提交json数据示例
Jun 22 #PHP
PHP获取日期对应星期、一周日期、星期开始与结束日期的方法
Jun 22 #PHP
PHP实现将base64编码字符串转换成图片示例
Jun 22 #PHP
PHP实现正则匹配所有括号中的内容
Jun 22 #PHP
You might like
萌王史莱姆”萌王性别尴尬!那“萌战”归女组还是男?
2018/12/17 日漫
PHP解析url并得到url参数方法总结
2018/10/11 PHP
javascript call和apply方法
2008/11/24 Javascript
form表单只提交数据而不进行页面跳转的解决方案
2013/09/18 Javascript
FireBug 调试JS入门教程 如何调试JS
2013/12/23 Javascript
JavaScript onkeypress事件入门实例(按下或按住一个键盘按键)
2014/10/17 Javascript
JavaScript针对网页节点的增删改查用法实例
2015/02/02 Javascript
关于JavaScript的变量的数据类型的判断方法
2015/08/14 Javascript
js实现select二级联动下拉菜单
2020/04/17 Javascript
Javascript json object 与string 相互转换的简单实现
2016/09/27 Javascript
Javascript计算二维数组重复值示例代码
2016/12/18 Javascript
Vue 2.0在IE11中打开项目页面空白的问题解决
2017/07/16 Javascript
Vue学习笔记进阶篇之函数化组件解析
2017/07/21 Javascript
JS排序算法之冒泡排序,选择排序与插入排序实例分析
2017/12/13 Javascript
使用vue-cli编写vue插件的方法
2018/02/26 Javascript
浅谈React组件之性能优化
2018/03/02 Javascript
微信小程序 动态修改页面数据及参数传递过程详解
2019/09/27 Javascript
Python内置数据类型详解
2014/08/18 Python
Python基于twisted实现简单的web服务器
2014/09/29 Python
Windows下Anaconda的安装和简单使用方法
2018/01/04 Python
python 限制函数调用次数的实例讲解
2018/04/21 Python
Python3.6使用tesseract-ocr的正确方法
2018/10/17 Python
对DataFrame数据中的重复行,利用groupby累加合并的方法详解
2019/01/30 Python
Python实现根据日期获取当天凌晨时间戳的方法示例
2019/04/09 Python
python psutil模块使用方法解析
2019/08/01 Python
Tensorflow读取并输出已保存模型的权重数值方式
2020/01/04 Python
Python对象的属性访问过程详解
2020/03/05 Python
pycharm 激活码及使用方式的详细教程
2020/05/12 Python
使用pandas库对csv文件进行筛选保存
2020/05/25 Python
python能开发游戏吗
2020/06/11 Python
Python APScheduler执行使用方法详解
2020/12/10 Python
一款纯css3实现的响应式导航
2014/10/31 HTML / CSS
利用HTML5中的Canvas绘制一张笑脸的教程
2015/05/07 HTML / CSS
First Aid Beauty官网:FAB急救面霜
2018/05/24 全球购物
生产经理的自我评价分享
2013/11/07 职场文书
党员承诺书格式范文
2015/04/28 职场文书