SpeedPHP/分页
SpeedPHP | 快速入门 | 访问交互 | 数据操作 | 框架概述 | 模板引擎 | 优化加速 | 开发指南 | 数据模型 | API参考 |
本条目介绍如何生成带分页的列表式页面的静态HTML。
生成分页的静态HTML页面[ ]
例子下载:http://speedphp.com/cms/uploads/html-sppager.zip
首先我们导入例子压缩包中的SQL文件到mysql数据库中,数据表很简单只有ID和contents两个字段,我们的分页例子就使用这个数据表来分页。
SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- Table structure for test_guestbook -- ---------------------------- DROP TABLE IF EXISTS `test_guestbook`; CREATE TABLE `test_guestbook` ( `id` int(11) NOT NULL AUTO_INCREMENT, `contents` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; -- ---------------------------- -- Records -- ---------------------------- INSERT INTO `test_guestbook` VALUES ('1', 'abc'); INSERT INTO `test_guestbook` VALUES ('2', 'ddd'); INSERT INTO `test_guestbook` VALUES ('3', 'eee'); INSERT INTO `test_guestbook` VALUES ('4', 'bccc'); INSERT INTO `test_guestbook` VALUES ('5', '333');
然后,我们设置一下例子入口文件的配置——框架的位置——因为例子为了文件保持小些,所以都没带SP框架,要自行设置框架的位置。
看看main.php控制器,index动作是生成分页的静态HTML操作,show动作是这个分页列表的显示。
<?php class main extends spController { function index(){ $count = spClass('guestbook')->findCount(); $urls = array(); for($i = 1;$i <= ceil($count/2);$i++) { $urls[] = array( array('main', 'show', array('page'=>(int)$i)) ); } spClass('spHtml')->makeAll($urls); } function show(){ $this->data = spClass('guestbook')->spPager($this->spArgs('page',1), 2)->findAll(); $this->pager = spClass('guestbook')->spPager()->getPager(); $this->display('main_show.html'); } } ?>
show动作里面,仍然是用spPager来获取分页数据并显示在页面上。
index动作,通过查询findCount获取了数据表的总记录数量,然后计算出总页面数量,循环将页面page参数赋值给页面生成的$urls中的url参数中。
这样就可以生成各个分页页面的静态HTML了。
参考来源[ ]
http://speedphp.com/manual.html
SpeedPHP使用手册导航 | ||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|