PHP템플릿 엔진Smarty 내장 함수 foreach 및 foreachelse의 사용법을 주로 소개하고, foreach 및 foreachelse의 기능과 구체적인 사용 기법을 예제 형식으로 분석합니다. 자세한 내용은 다음과 같습니다.
Smarty에서 템플릿의 경우 foreach를 사용하여 블록을 반복할 수 있습니다. 템플릿에서는 PHP에서 배열을 할당해야 합니다. 이 배열은 다차원 배열일 수 있습니다. Smarty의 {foreach} 태그는 그 중 하나가 템플릿 파일에 사용되고 다른 하나는 PHP 스크립트에 사용된다는 점을 제외하면 PHP의 foreach와 동일합니다. 따라서 구문이 달라집니다. 그러나 모두 동일한 작업을 수행합니다. 즉 배열의 내용을 탐색하는 것입니다. {foreachelse} 태그 반대편에는 {foreachelse} 태그도 있습니다. {foreachelse} 태그의 기능은 다음과 같습니다. 배열이 비어 있으면 태그의 내용이 실행됩니다. {foreach} 및 {/foreach}는 템플릿에서 쌍으로 나타나야 합니다. 여기에는 4개의 매개변수가 있으며 그 중 2개의 매개변수 from 및 item이 필요합니다. 해당 매개변수는 아래 목록을 참조하세요.
Attributes | Type | 필요합니까 | 기본값 | Description |
---|---|---|---|---|
from | string | 예 | 해당 없음 | 루프할 배열의 이름 |
item | string | Yes | n/a | 현재 처리 중인 요소의 변수 이름 |
key | 문자열 | No | n/a | 현재 처리 중인 요소의 키 이름 |
name | string | No | n/a | 이름은 루프에 액세스하는 데 사용되는 루프 |
예제를 사용하여 Smarty에서 {foreach} 및 {foreachelse}의 사용을 보여줍니다.
예제 아이디어: 데이터베이스에서 콘텐츠를 가져와 배열 변수 $_html에 할당하고 이 배열 변수를 템플릿에 할당한 다음 템플릿의 배열
test.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', '2011-10-24 00:00:00'), (3, '赤木晴子', 'chimiqingzi@yahoo.com,cn', '2011-10-24 00:00:00'), (4, '流川枫', 'lcfeng@sina.com', '0000-00-00 00:00:00'), (5, '蜡笔小新', 'labixiaoxin@sina.com', '2011-10-24 00:00:00'), (6, '金刚葫芦娃', 'jghlw@sina.com', '2011-10-24 00:00:00');
init.inc.php (템플릿 초기화 파일)
<?php define('ROOT_PATH', dirname(FILE)); //设置网站根目录 require ROOT_PATH.'/libs/Smarty.class.php'; //加载 Smarty 模板引擎 $_tpl = new Smarty(); //创建一个实例对象 $_tpl->template_dir = ROOT_PATH.'/tpl/'; //重新指定模板目录 $_tpl->compile_dir = ROOT_PATH.'./com/'; //重新指定编译目录 $_tpl->left_delimiter = '<{'; //重新指定左定界符 $_tpl->right_delimiter = '}>'; //重新指定右定界符 ?>
index.php (메인 파일)
<?php require 'init.inc.php'; //引入模板初始化文件 global $_tpl; $_mysqli = new mysqli(); //创建一个 mysqli() 对象 $_mysqli->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의 템플릿 파일)
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>foreach,foreachelse</title> </head> <body> <table align="center" border="1" width="800"> <{foreach from=$data item="row" name="ls"}> <!-- 这个foreach 循环分配过来的数组有几行数据 --> <!-- 在此,我们做几个保留变量 $smarty.foreach 的操作 --> <!-- 当数据显示第一条的时候,第一行的表格背景为黄色,使用属性:first --> <!-- 当数据显示最后一条的时候,最后一行的表格背景为蓝色,使用属性:last --> <!-- 显示下分配过来的数组的总个数,使用属性:total --> <{if $smarty.foreach.ls.first}> <tr bgcolor="#FFFF00"> <!-- 第一行背景为黄色 --> <{elseif $smarty.foreach.ls.last}> <tr bgcolor="#0000FF"> <!-- 最后一行背景为蓝色 --> <{else}> <tr> <{/if}> <td><{$smarty.foreach.ls.iteration}></td><!-- 注意:这里是保留变量 $smarty.foreach 的使用,iteration:总是从 1 开始,每执行一次增加 1 --> <{foreach from=$row item="col" name="lsin"}> <!-- 这个foreach 循环数组内的内容,显示在表格的<td></td>标签里 --> <td><{$col}></td> <{/foreach}> </tr> <{foreachelse}> <!-- 如果分配过来的数组中没有数据,那么就执行下面的操作! --> <tr> <td>对不起!暂时没有数据。</td> </tr> <{/foreach}> <tr> <td colspan="4" align="center">分配数组的总记录数为:<{$smarty.foreach.ls.total}>条</td> </tr> </table> </body> </html>
실행 결과:
마지막으로 메인 파일 index.php에 전달된 $_html 배열은 2차원 배열입니다. 예약된 변수 $smarty.foreach의 사용은 {foreach} 태그의 name 속성을 기반으로 합니다. 사용되는 예약된 변수 속성은 first(첫 번째 레코드), last(마지막 레코드), iteration(항상 1부터 시작, 각 실행)입니다. 1) 증가, 합계(루프 실행 횟수를 표시하는 데 사용)
위 내용은 Smarty 템플릿의 foreach 및 foreachelse 사용 코드 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!