本文实例讲述了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" rel="external nofollow" rel="external nofollow" >2</a></li> <li> <a href="/xkershouche/public/admin/selfattribute/lst.html" rel="external nofollow" >3</a></li> <li> <a href="/xkershouche/public/admin/selfattribute/lst.html" rel="external nofollow" >4</a></li> <li> <a href="/xkershouche/public/admin/selfattribute/lst.html" rel="external nofollow" >5</a></li> <li> <a href="/xkershouche/public/admin/selfattribute/lst.html" rel="external nofollow" >6</a></li> <li> <a href="/xkershouche/public/admin/selfattribute/lst.html" 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程序设计有所帮助。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月29日
2024年11月29日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]