#1 jake
本文介绍如何生成带分页的列表式页面的静态HTML。
例子下载:html-sppager[1].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动作是这个分页列表的显示。
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了。
2012-08-04 23:18:35