您的位置:首页技术文章

Zend Framework 入门(4)—页面布局

【字号: 日期:2023-11-19 10:39:31浏览:43作者:馨心

Zend Framework 的页面布局模块——Zend_Layout——既可以跟 MVC 一起使用,也可以单独使用。本文只讨论与 MVC 一起使用的情况。

1. 布局脚本

在 application/views 下创建一个layouts 的文件夹。主布局脚本 layout.phtml 代码如下:<?php echo $this->doctype('XHTML1_STRICT') ?><html><head><meta http-equiv='Content-Type' content='text/html; charset=utf-8' /><?php echo $this->headTitle() ?><?php$this->headLink()->appendStylesheet('/styles/main.css');// add more links ...?><?php echo $this->headLink() ?></head><body><div id='header'><?php echo $this->partial('header.phtml') ?></div><table><tr><td valign=top><div id='leftcolumn'><?php echo $this->partial('leftcolumn.phtml') ?></div></td><td valign=top><div id='content'><?php echo $this->layout()->content ?></div></td></tr></table><div id='footer'><?php echo $this->partial('footer.phtml') ?></div></body></html>

除了layout.phtml 之外,还需要编写 header.phtml,leftcolumn.phtml,footer.phtml,以及 main.css 等文件。

Zend Framework 的文档中用一个视图表示了页面布局的应用。

2. 设置页面布局

在 MVC 下设置页面布局非常简单,编辑 html/index.php,加入下面两行代码:

/** Setuplayout*/require_once 'Zend/Layout.php';Zend_Layout::startMvc($rootPath . '/application/views/layouts');

注意:在启动页面布局后,要调整已有的各个页面,把不需要的 html 元素,如<header> <title> <body> 等去掉。另外,可以通过 $this->headTitle() 来设置页面的题头。

改变页面的布局也很简单,只需在控制器中用下面的代码即可:

$this->_helper->layout->setLayout('new_layout');

如果一个控制器所有动作都使用同一个页面布局,可以通过控制器的初始化函数来设置:

public function init() {parent::init();

$this->_helper->layout->setLayout('new_layout');}

标签: PHP