ThinkPHP5.1+Ajax实现的无刷新分页功能示例
本文实例讲述了ThinkPHP5.1+Ajax实现的无刷新分页功能。分享给大家供大家参考,具体如下:
无刷新分页可以减轻服务器负担,利用Ajax技术,请求部分信息,提高网站访问速度,是网站建设的必备技术。
需要在后台展示自定义属性列表(lst.html),其中的列表部分摘出来,放到(paginate1.html)中:
| ID |
名称 |
取值 |
显示 |
排序 |
操作 |
{volistname="self"id="vo"}
| {$vo.id} |
{$vo.name} |
{$vo.value} |
{if$vo.isshow==1}
是
{else/}
否
{/if}
|
|
操作
修改
删除
|
{/volist}
{$self|raw}
排序
其中self是服务器端传递过来的自定义属性,并进行了分页操作:
$selfattribute_select=db("selfattribute")->paginate(5);
$this->assign("self",$selfattribute_select);
因为lst.html把列表摘了出来,所以还要在引入回去,才能使页面完整,同时,为了方便进行jquery操作,把列表用带id的div包裹起来:
{includefile="selfattribute/paginate1"}
ThinkPHP5.1带的分页类使用的是BootStrap样式,它在页面显示时实际会有一个pagination的类,查看源代码如下:
«
1
2
3
4
5
6
»
这就是好多人搞不懂的pagination是怎么来的。
然后开始写js代码,因为我们的分页按钮也在被请求的页面当中,属于“未来”的元素,所以这里我们要用on方法,这个方法是jquery1.7以后的方法,注意自己的jquery版本。
$(document).on('click','.paginationa',function(event){
varurl=$(this).attr('href');
$.ajax({
url:url,
type:'get',
})
.done(function(data){
$("#paginate").html(data);
})
returnfalse;
});
其中.done()方法和success方法是一样的,returnfalse是为了阻止默认事件,防止直接跳转。
那么服务器端就可以根据情况渲染模板了,代码如下:
publicfunctionlst()
{
$selfattribute_select=db("selfattribute")->paginate(5);
$this->assign("self",$selfattribute_select);
if(request()->isAjax()){
returnview("paginate1");
}else{
returnview();
}
}
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《ZendFrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。