#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