[转]ThinkPHP中分页加上搜索

ThinkPHP 分页可以很容易的实现对不固定查询参数的支持。具体实现是给分页类的 parameter 属性赋值或者直接实例化分页类时传入查询参数。下面以例子来说明。
parameter 属性赋值

例如要检索用户表中状态为 1 (status=1) 并且电子包含 163 的用户,当提交表单时(注意表单是 GET 方式提交),形成的 URL 地址大致如下:

public function search(){

    $Dao = M("User");

    // 构造查询条件

    $condition['status'] = $_GET['status'];

    $condition['email'] = array('like',"%".$_GET['email']."%");

    // 计算总数

    $count = $Dao->where($condition)->count();

    // 导入分页类

    import("ORG.Util.Page");

    // 实例化分页类

   $p = new Page($count, 10);

    // 获取查询参数

    $map['status'] = $_GET['status'];

    $map['email'] = $_GET['email'];

    foreach($map as $key=>$val) { 

        $p->parameter .= "$key=".urlencode($val)."&"; 

    }

    // 分页显示输出

    $page = $p->show();

 

    // 当前页数据查询

    $list = $Dao->where($condition)->order('uid ASC')->limit($p->firstRow.','.$p->listRows)->select();

 

    // 赋值赋值

    $this->assign('page', $page);

    $this->assign('list', $list);


    $this->display();

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值