名称名称
名称,用于访问该循环
我们通过一个实例,来演示 Smarty 中 {foreach} 和 {foreachelse} 的使用。
实例思路:从数据库中取出内容,赋给一个数组变量 $_html ,再给这个数组变量分配给模板,然后在模板中进行该数组的遍历
test.sql (使用到的 sql 数据)
sql;">
--
-- 表的结构 `user`
--
CREATE TABLE IF NOT EXISTS `user` (
`id` mediumint(8) unsigned NOT NULL auto_increment,`username` varchar(50) NOT NULL,`email` varchar(50) NOT NULL,`addTime` datetime NOT NULL default '0000-00-00 00:00:00',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ;
--
-- 转存表中的数据 `user`
--
INSERT INTO `user` (`id`,`username`,`email`,`addTime`) VALUES
(1,'苍井空','canjingkong@sina.com.cn','2011-10-24 00:00:00'),(2,'樱木花道','ymhd@163.com',(3,'赤木晴子','chimiqingzi@yahoo.com,cn',(4,'流川枫','lcfeng@sina.com','0000-00-00 00:00:00'),(5,'蜡笔小新','labixiaoxin@sina.com',(6,'金刚葫芦娃','jghlw@sina.com','2011-10-24 00:00:00');
init.inc.PHP (模板初始化文件)
PHP;">
template_dir = ROOT_PATH.'/tpl/'; //重新指定模板目录
$_tpl->compile_dir = ROOT_PATH.'./com/'; //重新指定编译目录
$_tpl->left_delimiter = '<{'; //重新指定左定界符
$_tpl->right_delimiter = '}>'; //重新指定右定界符
?>
index.PHP(主文件)
PHP;">
connect('localhost','root','
数据库密码','
数据库名'); //连接
数据库,请您自行设置
$_
MysqLi->set_charset('utf8'); //设置编码
$_result = $_
MysqLi->query("select username,email,addTime from user order by id asc");
$_html = array();
while (!!$_row=$_result->fetch_assoc()) {
$_html[] = $_row;
}
$_tpl->assign('data',$_html); //把数组分配到模板中
$_tpl->display('index.tpl'); //引入模板
$_
MysqLi->close(); //
关闭数据库,释放资源
?>
tpl/index.tpl(主文件 index.PHP 的模板文件)
PHP;">
<
Meta http-equiv="Content-Type" content="text/html; charset=utf-8">
foreach,foreachelse
<{if $smarty.foreach.ls.first}>
<{elseif $smarty.foreach.ls.last}>
<{else}>