Thinkphp内置分页类Page.class.php,位于ThinkPHP\Lib\ORG\Util下,在写程序的时候想要引用该类时导入方式 import("ORG.Util.Page");
function index(){
$User= M("User");//实例化User对象
import("ORG.Util.Page");//导入分页类
$count=$User->where("status=1")->count();//查询满足要求的总记录数
$Page= new Page($count,25);//实例化分页类传入总记录数和每页显示的记录数
$show= $Page->show();//分页显示输出
//进行分页数据查询注意limit方法的参数要使用Page类的属性
$list=$User->where('status=1')->order('id')->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('list',$list);//赋值数据集
$this->assign('page',$show);//赋值分页输出
$this->display();//输出模板
}
新建分页类时,代码为:
$p=new Page($totalRows,$listRows=”,$parameter=”);
/*$totalRows为总的记录数,整型;$listRows 每页显示记录数,整型;$parameter为分页跳转的参数,数组。其中创建新类时第一个参数不可缺;第二个参数缺时用默认值10,第三个参数是分页跳转时链接后带的GET参数,一般不需要。当确实要带参数时,就可加上。
分页原理:其实就是先查出要显示的数据有多少条,再根据每页显示条数得出要显示多少页,再计算出每一页对应的是最终要查询的数据的第多少条到第多少条,然后利用内置查询函数如findall()等向数据库查询显示该页对应的记录条数。
更多学习到http://sjolzy.cn/Php.html上,不光有Thinkphp,