1.最简单的DEMO
在上一篇文章已经演示了最简单的demo,再来回顾一下上篇章中的文档结构和控制器代码:
A. 先看左边的代码结构:
|_ application:应用程序目录
| |_ modules:MVC模块目录
| |_manage:“manage”模块
| |_ controllers:“manage”模块下的控制器目录
| _ library:类目录
|_ Zend:ZF类库
说明:
a).application下可以放config、input、model等代码;
b).modules下只创建了一个模块“manage”,根据需要可以放其他的模块;
c).library下可以放第三方或自己开发的类库,后文将会用到。
B.再看右边的控制器代码:
a).控制器名称须是“模块名_控制器名Controller“;
b).须从Zend_Cotroller_Action继承;
c).Action名称必须以Action结尾。
2.最简单的视图页面
上例中的demo是直接返回一个字符串,并未引用到页面。现在我们来创建一个hello world页面,步骤如下:
A.在manage模块下创建视图目录“views/scripts/demo”,其中前二级目录名称是固定的,demo与控制器名称对应;
B.在"manage/views/scripts/demo"目录下创建文件“hello.phtml”,内容如下:
<h1>Hello World!!!</h1>
完成后的项目结构如下:
C..修改DemoController类的helloAction方法:
public function helloAction() {
$view = new Zend_View ();//创建视图对象
$view->setScriptPath ( './application/modules/manage/views/scripts/demo' );//设置视图文件的目录
$this->getResponse ()->insert ( 'body', $view->render ( 'hello.phtml' ) );//返回hello.phtml视图页面
}
D.测试访问:http://localhost/manage/demo/hello,内容如下:
3.使用布局的视图
在上一示例中直接返回一个视图页面,但在实际的项目中我们会为相似的页面创建一个模板,在ASP.NET中称之为“母版”,而在ZF中称之为“布局”。
我们来改造一下:
A.在views目录下创建模版(布局)目录“layouts”;
B.在“layouts”下创建布局“master.pthml”,内容如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>DEMO</title>
</head>
<body>
<?php echo $this->layout()->body ?>
</body>
</html>
C.修改DemoController类的helloAction方法,完成后的代码如下:
<?php
class Manage_DemoController extends Zend_Controller_Action {
public function helloAction() {
$view = new Zend_View ();
$view->setScriptPath ( './application/modules/manage/views/scripts/demo' );
Zend_Layout::startMvc ( './application/modules/manage/views/layouts' );//设置布局目录
$this->_helper->layout->setLayout ( 'master' );//使用master布局,这里不需要扩展名
$this->getResponse ()->insert ( 'body', $view->render ( 'hello.phtml' ) );
}
}
D.测试访问效果如下:
注意页面的标题是“DEMO”了。