发布于 2015-10-07 09:52:47 | 312 次阅读 | 评论: 0 | 来源: 网络整理
目录
Zend_View是用来在MVC模式中处理View(视图)部份的一个类。也就是说它用来使视图部份的代码与Model及controller部分分离。它提供了helper,output filter,variable escaping等几个功能组件。
Zend_View使用PHP本身作为你的模板,或者你也可以建立其它模板引擎的实例,并用你的view代码来对其进行操作。
使用Zend_View主要有两步: 1. 你的Controller建立一个Zend_View实例,并将需要的变量传递给它; 2. Controller告诉Zend_View解析一个特定的视图,生成View输出的内容。
下面是一个简单的例子。假设你有一个书籍清单,想把它打印出来。控制器代码可能看起来是这样的:
<?php
//使用一个模型来获取书籍作者和标题相关数据。
$data = array(
array(
'author' => 'Hernando de Soto',
'title' => 'The Mystery of Capitalism'
),
array(
'author' => 'Henry Hazlitt',
'title' => 'Economics in One Lesson'
),
array(
'author' => 'Milton Friedman',
'title' => 'Free to Choose'
)
);
//传递数据给Zend_View类的实例
Zend_Loader::loadClass('Zend_View');
$view = new Zend_View();
$view->books = $data;
//解析一段View代码"booklist.php"来显示数据
echo $view->render('booklist.php');
现在我们看看相关的视图代码"booklist.php"。这是一段普通的代码,但是有一点特别:它是在Zend_View实例的内部运行的,所以$this指向的是Zend_View实例和类方法。(controller传递给Zend_View实例的变量是public的)。一段非常基本的视图代码看起来是这样的:
<?php if ($this->books): ?>
<!-- 包含几本书信息的HTML表格. -->
<table>
<tr>
<th>Author</th>
<th>Title</th>
</tr>
<?php foreach ($this->books as $key => $val): ?>
<tr>
<td><?php echo $this->escape($val['author']) ?></td>
<td><?php echo $this->escape($val['title']) ?></td>
</tr>
<?php endforeach; ?>
</table>
<?php else: ?>
<p>There are no books to display.</p>
<?php endif; ?>
注意我们使用escape()来转义输出。
Zend_View有若干选项来配置视图脚本的运行。
basePath: 指示一个基本路径,可以在下面设置script、 helper 和 filter 路径。目录结构如下:
base/path/
helpers/
filters/
scripts/
可以通过 setBasePath()、addBasePath()、或 basePath设置给构造器。
encoding: 指定 htmlentities()、htmlspecialchars()和其它操作所采用的字符集,缺省为 ISO-8859-1 (latin1)。也可以通过setEncoding() 或 encoding 设置给构造器。
escape: 指定escape()所使用的回调函数(callback)。也可以通过setEscape()或escape设置给构造器。
filter: 指示在解析视图脚本后使用的过滤器。可以通过setFilter()、addFilter()或者filter设置给构造器。
strictVars: 指定某些未初始化的视图变量被访问时,Zend_View必须发出通知和警告。可以通过调用strictVars(true) 或传递strictVars给构造器来设置。
一般来说,你只需要调用assign()、render()或其中之一来设置/添加过滤器、助手类、和脚本路径。然而,如果希望扩展Zend_View或需要访问它的内部,有许多访问器(Accessor)可用:
getVars() 将返回所有已赋值的变量。
clearVars() 将清除所有已赋值的变量;当你想重新使用同一个视图对象,并决定哪些变量可用时,这个功能很有用。
getScriptPath($script) 将获取指定的视图脚本的路径。
getScriptPaths() 将获取所有注册的脚本路径。
getHelperPath($helper) 将获取已命名的助手类的路径。
getHelperPaths() 将获取所有注册的助手路径。
getFilterPath($filter) 将获取已命名的过滤器类的路径。
getFilterPaths() 将获取所有注册的过滤器文件的路径。