黑马lavarel教程---13、分页

一、总结

一句话总结:

- lavarel里面的分页操作和tp里面的分页操作几乎是一模一样的
- 控制器:$data=Lesson::paginate(2);
- 视图:{{$data->links()}}

二、数据分页

在laravel里面要完成分页是很简单的,它的思想之前的框架有些不一样,之前框架使用的是分页类完成分页,laravel是直接调用模型的分页方法,返回对应的数据和分页的字符串。

分页类的在框架中的位置(了解):

案例:使用分页功能实现当前member数据表的分页效果。由于数据量较少,可以考虑每页显示1个记录,重点是分页的效果

回忆/问题:分页效果的实现大致需要哪几个步骤才能实现?

a. 查询符合分页条件的总的记录数

b. 计算总的页数(总记录数/每页记录数,并且向上取整)

c. 拼凑分页的链接

d. (核心)使用limit语法来限制分页的记录数

e. 展示分页的页码和分页数据

f. 如果可以,建议去考虑下分页的样式显示问题

①创建路由,并且展示简易列表页面(table标签布局)

路由:

创建列表文件:

②编写控制器中的方法代码,实现没有分页的效果(先不考虑分页效果)

③展示数据

无分页展示效果:

④【案例】使用分页展示上述的页面

要求:每页显示一条记录。

在laravel中分页有2个提供者:DB查询构建器,另外可以使用模型来实现

用法基本一致。

以模型为例:

分页的基本语法:

Model::paginate(每页显示的记录数)                  同样,paginate和get一样,支持使用where以及orderBy等辅助查询的方法。

不展示分页链接的效果:

在页面中展示分页链接:

语法:{{$保存数据的对象 -> links()}}生成的链接

目前显示效果:

⑤【可选】将页面的提示“>>”和“<<”改成上一页和下一页提示文字

直接改源码文件:

改为提示文字:

注意:可以使用simplePaginate()表示简单分页,只有上一页和下一页,没有分页字符串。

例如:$info = Member::orderby('age','desc')->simplePaginate(2);

附:分页数据对象的其他实用方法如下

分页数据对象->count()                             //当前页数据条数

分页数据对象->currentPage()         //当前页码

分页数据对象->firstItem()                     //当前页第一条数据的序号

分页数据对象->hasMorePages()             //是否有后续页码

分页数据对象->lastItem()                     //当前页最后一条数据的序号

分页数据对象->lastPage()                       //最后页序号

分页数据对象->nextPageUrl()          //下一页的链接地址

分页数据对象->perPage()                          //每页显示数据条数

分页数据对象->previousPageUrl()  //上一页的链接地址

分页数据对象->total()                                    //记录总条数

分页数据对象->url(5)                        //制作指定页码的链接地址

将页码稍作处理,写的好看点:

样式代码可以百度上寻找:https://www.cnblogs.com/lamp01/p/6869762.html

将css代码引入到当前的分页页面,最终显示效果:

 

黑马lavarel教程---13、分页的更多相关文章

  1. 黑马lavarel教程---5、模型操作(AR模式)

    黑马lavarel教程---5.模型操作(AR模式) 一.总结 一句话总结: AR: ActiveRecord :Active Record(活动记录),是一种领域模型模式,特点是一个模型类对应关系型 ...

  2. 黑马lavarel教程---1、lavarel目录结构

    黑马lavarel教程---1.lavarel目录结构 一.总结 一句话总结: 一套视频讲的东西太少,要看多套视频 1.安装lavarel需要额外开启的模块? extension=php_filein ...

  3. 黑马lavarel教程---9、缓存操作

    黑马lavarel教程---9.缓存操作 一.总结 一句话总结: legend2项目中自己写的哪些文件操作都可以通过这里的缓存实现,简单方便 1.lavarel中如何使用后端主流的缓存如 Memcac ...

  4. 黑马lavarel教程---12、lavarel验证码

    黑马lavarel教程---12.lavarel验证码 一.总结 一句话总结: 用插件的时候仔细看插件的版本要求 1.lavarel安装验证码插件的时候,如果(可选)需要定义自己的配置,则需要生成配置 ...

  5. 黑马lavarel教程---11、响应处理

    黑马lavarel教程---11.响应处理 一.总结 一句话总结: 如果在昂扬状态,看学习视频和运动时间重合,会很舒服 1.jquery的$.post参数为什么不需要占位? 因为每个参数的类型不同,可 ...

  6. 黑马lavarel教程---10、lavarel模型关联

    黑马lavarel教程---10.lavarel模型关联 一.总结 一句话总结: 1.模型关联比较方便,一次定义,后面都可以使用 2.关联关系 使用动态属性进行调用 1.一对多,多对多实例? 一对多: ...

  7. 黑马lavarel教程---8、session

    黑马lavarel教程---8.session 一.总结 一句话总结: 1.session默认保存在文件中 2.使用的话通过Session门面或者辅助函数 1.lavarel中session的保存方式 ...

  8. 黑马lavarel教程---7、文件上传

    黑马lavarel教程---7.文件上传 一.总结 一句话总结: 在laravel里面实现文件的上传是很简单的,压根不用引入第三方的类库,作者把上传作为一个简单的http请求看待的. 1.在lavar ...

  9. 黑马lavarel教程---6、简单验证

    黑马lavarel教程---6.简单验证 一.总结 一句话总结: 1.验证的最简单实例:$request的validate方法,验证通过可以继续进行,验证失败就重定向 2.中文提示可以用中文语言包 3 ...

随机推荐

  1. 【持续集成工具】 Jenkins

    一.什么是持续集成 持续集成(CI):简单来说就是指将开发者的工作内容频繁地集成到主干中. 而持续集成工具可以将开发者频繁需要构建,编译,测试,部署等操作自动进行,为开发提供了非常大便利. 二.持续集 ...

  2. windows2012获取明文密码

    windows 2012获取明文密码 导hash的话用常规的方法就可以. 修改注册表 reg add HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Contr ...

  3. vue中移动端滚动事件,点击一次触发了事件两次(better-scroll)

    解决办法一: 将button标签换成a标签 问题代码: <span class="submitBtn" @click.stop="replyReport()&quo ...

  4. Oracle笔记(二) SQLPlus命令

    对于Oracle数据库操作主要使用的是命令行方式,而所有的命令都使用sqlplus完成,对于sqlplus有两种形式. 一种是dos风格的sqlplus:sqlplus.exe; 另一种是window ...

  5. win10 修改文件夹右击默认打开程序

    1.注册表打开 cmd  regedit 2.打开如下位置 3.编辑图中2个Anycode.command的值 为打开 保存即可

  6. 【转】(深入理解计算机系统) bss段,data段、text段、堆(heap)和栈(stack)

    bss段: bss段(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域. bss是英文Block Started by Symbol的简称. bss段属于静态内存分配. ...

  7. Ubuntu18.04安装 NVIDIA驱动

    Ubuntu18.04安装 NVIDIA驱动 参考自博客:https://blog.csdn.net/jsjason1/article/details/88086904 我确定这篇文章是否很有必要,我 ...

  8. dedecms织梦后台发布文章提示“标题不能为空”的解决办法

    V5.7登录后台后,发布英文标题没问题,发布中文会提示“标题不能为空”. 原因:htmlspecialchars在php5.4默认为utf8编码,gbk编码字符串经 htmlspecialchars ...

  9. 通过url下载文件到指定目录 java

    import java.io.DataInputStream; import java.io.DataOutputStream; import java.io.File; import java.io ...

  10. 初始Ajax学习笔记

    前端: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <!--引入 ...