手册 >> 优化加速 >> 生成分页的静态HTML页面

生成分页的静态HTML页面

本文介绍如何生成带分页的列表式页面的静态HTML。

例子下载: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了。