ThinkPHP5.1+Ajax实现的无刷新分页功能示例
时间:2022-07-27
本文章向大家介绍ThinkPHP5.1+Ajax实现的无刷新分页功能示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例讲述了ThinkPHP5.1+Ajax实现的无刷新分页功能。分享给大家供大家参考,具体如下:
无刷新分页可以减轻服务器负担,利用Ajax技术,请求部分信息,提高网站访问速度,是网站建设的必备技术。
需要在后台展示自定义属性列表(lst.html),其中的列表部分摘出来,放到(paginate1.html)中:
<div class="row"
<div class="col-sm-12"
<div class="ibox float-e-margins"
<div class="ibox-content"
<table class="table table-bordered"
<thead
<tr
<th ID</th
<th 名称</th
<th 取值</th
<th 显示</th
<th 排序</th
<th 操作</th
</tr
</thead
<tbody
{volist name="self" id="vo"}
<tr
<td {$vo.id}</td
<td {$vo.name}</td
<td {$vo.value}</td
<td
{if $vo.isshow==1}
<button type="button" class="btn btn-success btn-sm" 是</button
{else/}
<button type="button" class="btn btn-danger btn-sm" 否</button
{/if}
</td
<td <input type="text" value="{$vo.order}" name="" </td
<td
<div class="btn-group open"
<button data-toggle="dropdown" class="btn btn-primary dropdown-toggle" aria-expanded="true" 操作 <span class="caret" </span
</button
<ul class="dropdown-menu"
<li <a href="" 修改</a
</li
<li <a href="" 删除</a
</li
</ul
</div
</td
</tr
{/volist}
</tbody
</table
{$self|raw}
<div class="row"
<div class="col-sm-2"
<button class="btn btn-success" type="button" id="changeOrder"
<i class="fa fa-plus-square" </i
<span class="bold" 排序</span
</button
</div
</div
</div
</div
</div
</div
其中self是服务器端传递过来的自定义属性,并进行了分页操作:
$selfattribute_select = db("selfattribute")- paginate(5);
$this- assign("self",$selfattribute_select);
因为lst.html把列表摘了出来,所以还要在引入回去,才能使页面完整,同时,为了方便进行jquery操作,把列表用带id的div包裹起来:
<div id="paginate"
{include file="selfattribute/paginate1"}
</div
ThinkPHP5.1带的分页类使用的是BootStrap样式,它在页面显示时实际会有一个pagination的类,查看源代码如下:
<ul class="pagination"
<li class="disabled"
<span «</span </li
<li class="active"
<span 1</span </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=2" rel="external nofollow" rel="external nofollow" 2</a </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=3" rel="external nofollow" 3</a </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=4" rel="external nofollow" 4</a </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=5" rel="external nofollow" 5</a </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=6" rel="external nofollow" 6</a </li
<li
<a href="/xkershouche/public/admin/selfattribute/lst.html?page=2" rel="external nofollow" rel="external nofollow" »</a </li
</ul
这就是好多人搞不懂的pagination是怎么来的。
然后开始写js代码,因为我们的分页按钮也在被请求的页面当中,属于“未来”的元素,所以这里我们要用on方法,这个方法是jquery1.7以后的方法,注意自己的jquery版本。
<script type="text/javascript"
$(document).on('click', '.pagination a', function(event) {
var url = $(this).attr('href');
$.ajax({
url: url,
type: 'get',
})
.done(function(data) {
$("#paginate").html(data);
})
return false;
});
</script
其中.done()方法和success方法是一样的,return false是为了阻止默认事件,防止直接跳转。
那么服务器端就可以根据情况渲染模板了,代码如下:
public function lst()
{
$selfattribute_select = db("selfattribute")- paginate(5);
$this- assign("self",$selfattribute_select);
if (request()- isAjax()) {
return view("paginate1");
} else {
return view();
}
}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
- 数据分析小案例(二):面包是不是变轻了(python)
- 数据分析小案例(一):商业街抽奖(python)
- Bagging算法(R语言)
- iOS @property探究(一): 基础详解你要知道的@property都在这里
- 在创建带输出参数和返回值的存储过程时---犯下的一个低级错误
- iOS block探究(二): 深入理解你要知道的block都在这里
- 使用开源人脸特征提取器进行脸部颜值评分
- iOS @property探究(二): 深入理解你要知道的@property都在这里
- iOS block探究(一): 基础详解你要知道的block都在这里
- 在不动用sp_configure的情况下,如何 =》去掉列的自增长,并保留原数据
- iOS runtime探究(一): 从runtime开始理解面向对象的类到面向过程的结构体你要知道的runtime都在这里
- iOS runtime探究(二): 从runtime开始深入理解OC消息转发机制你要知道的runtime都在这里
- SpringMVC 启动流程及相关源码分析你要知道的SpringMVC启动流程和源码分析都在这里
- iOS runtime探究(四): 从runtiem开始实践Category添加属性与黑魔法method swizzling你要知道的runtime都在这里
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 突击并发编程JUC系列-并发工具 CyclicBarrier
- 详解 | Linux系统是如何实现存储并读写文件的?
- Angular单元测试的一个错误消息
- Python进行特征提取
- dotnet OpenXML 元素 cNvPr NonVisual Drawing Properties 的属性作用
- Java 对象相关面试题
- 【每日一题】【vue2源码学习】VUE中模版编译原理
- 【每日一题】【vue2源码学习】对VUE响应式数据的理解
- ApacheCN 深度学习译文集 2020.9
- 当Docker遇到Intellij IDEA,再次解放了生产力~
- 基于NPOI的Excel导入导出类库
- 在tinycolinux32上装tinycolinux64 kernel和toolchain
- 通过链下签名授权实现更少 Gas 的 ERC20代币
- 在dbcolinux上安装cozy-light
- 在群晖docker上装elmlang可视调试编码器ellie