ThinkPHP 整合Bootstrap Ajax分页样式

5年以前  |  阅读数:401 次  |  编程语言:PHP 

ThinkPHP Ajax分页代码


    publicfunction index()
    {
    $where=array();
    $name = I('name');
    if(!empty($name)){
    $where['name']= array('like','%'.(string)$name.'%');
    }
    $Role=M('Role');
    $count= $Role->where($where)->count();// 查询满足要求的总记录数
    $Page =new \Think\AjaxPage($count,'ajax-page',10);// 实例化分页类 传入总记录数、ajax更新的局部页面ID和每页显示的记录数(10)
    $Page->lastSuffix=false;
    $Page->setConfig('first','首页');
    $Page->setConfig('last','末页');
    $Page->setConfig('header','<span class="rows btn btn-default margin-l-2">共 %TOTAL_ROW% 条</span>');//分页条数
    $Page->setConfig('theme','%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END% %HEADER%');//分页样式:首页、末页等
    $show= $Page->show();// 分页显示输出
    // 进行分页数据查询 注意limit方法的参数要使用Page类的属性
    $datas = $Role->where($where)->order('id desc')->limit($Page->firstRow.','.$Page->listRows)->select();
    $this->assign('datas',$datas);// 赋值数据集
    $this->assign('page',$show);// 赋值分页输出
    if(IS_AJAX){
    $this->display('index_ajax');
    }else{
    $this->display();
    }
    }

ajax-page是模版中用于替换局部页面的ID

index_ajax是局部页面模版

扩展小部件ExtWidget

我是在Admin模块下建的这个类/Application/Admin/Widget/ExtWidget.class.php所有如下图

前台模版

我有个index.html模版,这个页面需要ajax分页,现在我建立一个index_ajax.html模版,如下图

index.html是有布局的模版,显示ajax分页地方的关键代码如下


    <table id="users"class="table table-bordered table-hover table-striped">
     <thead>
     <tr>
      <th><input class="check-all" type="checkbox"/></th>
      <th width="90%">名称</th>
      <th width="10%">操作</th>
     </tr>
     </thead>
     <tbody id="ajax-page">
     {:W('Ext/renderPartial',array('data'=>array('partial'=>'Role/index_ajax','data'=>$datas,'page'=>$page)))}
     </tbody>
    </table>

第一次页面加载的时候不是ajax渲染的页面,所以这里要调用一次index_ajax模版。当点击分页时ajax会替换掉这里的<tbody id="ajax-page"></tbody>内容


    {:W('Ext/renderPartial',array('data'=>array('partial'=>'Role/index_ajax','data'=>$datas,'page'=>$page)))}

index_ajax.html是没有布局的模版,只是为了显示数据。代码如下


     <notempty name="datas">
    <volist name="datas" id="vo">
    <tr>
    <td><input class="ids" type="checkbox" name="id[]" value="{$vo.id}"/></td>
    <td>{$vo.name}</td>
    <td>
    <span class="btn btn-xs btn-primary mySave" data-toggle="modal" data-id="{$vo.id}" data-url="{:U('/Admin/Role/update')}"><span class="glyphicon glyphicon-edit margin-r-2" aria-hidden="true"></span>修改</span>
    <a class="confirm ajax-get btn btn-xs btn-primary" href="{:U('/Admin/Role/del',array('id'=>$vo['id']))}"><span class="glyphicon glyphicon-remove" aria-hidden="true"></span> 删除</a>
    </td>
    </tr>
    </volist>
    <else/>
    <tr><td colspan="100"class="text-center">没有查询到数据!</td><tr>
    </notempty>
    <notempty name="page">
    <tr><td colspan="100"class="text-right">{$page}</td><tr>
    </notempty>

js代码如下


    //ajax分页查询
    function ajax_show(id,url){
    //加载图片
    $('#ajax-loading-img').html('<img src="/Public/img/loading.gif" class="margin-r-2" alt="加载中...">');
    //ajax获取内容后并替换掉原有信息
    $.get(url,function(data){$("#"+id).html(data);});
    returnfalse;
    }

效果图

ThinkPHP Ajax分页带参数查询

html代码


    <form class="navbar-form" role="search" id="search-form" method="get" action="{:U('/Admin/Role/index')}">
    <div class="form-group">
    名称:<input class="form-control" name="name" type="text">
    </div>
    <button type="submit"class="btn btn-primary" id="my-search"><span class="glyphicon glyphicon-glass margin-r-2" aria-hidden="true"></span>查询</button>
    </form>

js代码


    $(function(){
    $('#my-search').click(function(){
    var search_form=$("#search-form").serialize();//实例化查询参数
      var url="{:U('/Admin/Role/index')}"+'?'+search_form;//查询url
    return ajax_show('ajax-page',url);//调用ajax分页
    });
    });

效果图

可以看到分页的中已经有参数了,并且整个查询过程都是Ajax无刷新查询。

以上所述是小编给大家介绍的ThinkPHP 整合Bootstrap Ajax分页样式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例