この記事では、PHP テンプレート エンジン Smarty の組み込み関数 foreach と foreachelse の使い方を主に紹介し、foreach と foreachelse の機能と具体的な使用テクニックをサンプル形式で分析します。 Smarty テンプレートでは、foreach を使用してブロックを繰り返すことができます。テンプレートでは、PHPから配列を割り当てる必要があります。この配列は多次元配列にすることができます。 Smarty の {foreach} タグは、一方がテンプレート ファイルで使用され、もう一方が PHP スクリプトで使用されることを除いて、PHP の foreach と同じです。したがって、構文は異なります。ただし、それらはすべて同じこと、つまり配列の内容を反復処理することを行います。 {foreach} タグの反対側に {foreachelse} タグもあります。{foreachelse} タグの機能は次のとおりです。配列が空の場合、タグ内のコンテンツが実行されます。 {foreach} と {/foreach} はテンプレート内でペアで指定する必要があります。これには 4 つのパラメータがあり、そのうち 2 つのパラメータ from と item が必要です。パラメータについては、次のリストを参照してください:
属性
タイプ |
必須かどうか |
デフォルト値 |
説明 |
|
from
文字列 |
はい |
| n/aループされる配列の名前 |
|
item
string |
Yes |
|
n/a現在処理されている要素の変数名 |
|
key
string | いいえ このループの名前 (for ループにアクセスします) |
|
例を使用して、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 (最後のレコード)、繰り返し (常に 1 から始まります)、各実行1 ずつ増加します)、合計 (ループの実行数を表示するために使用されます)
概要: 上記がこの記事の全内容です。皆さんの学習に役立つことを願っています。
関連する推奨事項:
php
array_unshift()を使用した配列キーの変更に関するメモと分析例
php
HTML形式をテキスト形式に変換する方法
php
curlメソッドを使用するプロキシ経由でのデータ取得
以上がPHP テンプレート エンジン Smarty 組み込み関数 foreach、foreachelse の使用法と分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。