zend框架两步查看

时间:2012-07-10 01:59:39

标签: zend-framework

我是zendframework的新手。我正在尝试实施两步视图布局:

bootstrap.php中(图/ bootstrap.php中)

<?php

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{

     public function _initRoutes()
    {
        $options = array(
    'layout'     => 'layout',
    'layoutPath' => '/layout/layout.phtml',);
$layout = Zend_Layout::startMvc($options);
    }
}?>

layout.phtml(应用/视图/脚本/布局/ layout.phtml)

<?php
        include "header.php";

?>
// view contents goes here.
<?php

       $this->layout()->content;

?>
// footer goes here.
<?php
        include "footer.phtml";
?>

我是一个绝对的初学者,一步一步解释得更加赞赏。谢谢。

2 个答案:

答案 0 :(得分:3)

启用布局的最简单方法是从命令行zf enable layout运行Zend_Tool命令,这将添加行
 resources.layout.layoutPath = APPLICATION_PATH "/layouts/scripts/"
 到您的 application.ini 并构建布局目录和默认文件layout.phtml

或者,您可以在 application.ini 文件中指定2行的布局路径和默认布局名称:

resources.layout.layoutPath = APPLICATION_PATH "/layouts" //path to layout
resources.layout.layout = master //name of layout without extension

可以在您的application.ini中设置其他布局/视图选项,以便在您的视图中进行调用:

;View Settings
;*************
resources.view[]=
resources.view.charset = "UTF-8"
resources.view.encoding = "UTF-8"
resources.view.doctype = "HTML5"
resources.view.language = "en"
resources.view.contentType = "text/html; charset=UTF-8"

然后在 bootstrap.php 中,您可以调用这些资源来初始化您的视图:

 /**
     * initialize the registry and asign application.ini to config namespace
     */
    protected function _initRegistry() {

        //make application.ini configuration available in registry
        $config = new Zend_Config($this->getOptions());
        Zend_Registry::set('config', $config);
    }

    /**
     * initialize the view and return it
     * @return \Zend_View
     */
protected function _initView() {
        //Initialize view
        $view = new Zend_View();
        //add custom view helper path
        $view->addHelperPath('/../library/Application/View/Helper');
        //set doctype for default layout
        $view->doctype(Zend_Registry::get('config')->resources->view->doctype);
        //set default title
        $view->headTitle('Our Home');
        //set head meta data
        $view->headMeta()->appendHttpEquiv('Content-Type', Zend_Registry::get(
                        'config')->resources->view->contentType);
        //set css includes
        $view->headLink()->setStylesheet('/css/normalize.css');
        $view->headLink()->appendStylesheet('/css/blueprint/src/liquid.css');
        $view->headLink()->appendStylesheet('/css/blueprint/src/typography.css');
        $view->headLink()->appendStylesheet(
                '/javascript/mediaelement/build/mediaelementplayer.css');
        $view->headLink()->appendStylesheet('/css/main.css');
        $view->headLink()->appendStylesheet('/css/nav.css');
        $view->headLink()->appendStylesheet('/css/table.css');
        //add javascript files
        $view->headScript()->setFile('/javascript/mediaelement/build/jquery.js');

        //add it to the view renderer
        $viewRenderer = Zend_Controller_Action_HelperBroker::getStaticHelper(
                        'ViewRenderer');
        $viewRenderer->setView($view);
        //Return it, so that it can be stored by the bootstrap
        return $view;
    }

我还提供了一个方便的方法_initRegistry(),以最少的代码使配置选项无处不在。

ZF中的布局是一个简单的html页面,为动态或配置的选项添加了占位符:

<?php
echo $this->doctype() . "\n"; //placeholder assigned in bootstrap $view->doctype
?>
<html>
    <head>
        <title></title>
        <?php echo $this->headMeta() . "\n" //placeholder assigned in bootstrap ?>
        <?php echo $this->headLink() . "\n" //placeholder assigned in bootstrap ?>
        <?php echo $this->headscript(). "\n" //placeholder assigned in bootstrap?>
    </head>
    <body>
        <section class="container">
            <header class="block">
                <hgroup id="header" class ="column span-24">
                    <h1>Our Page</h1>
                </hgroup>
                <nav>
                    <div id="nav" class="column span-24">
                        <?php echo $this->layout()->nav //custom placeholder ?>
                    </div>
                </nav>
            </header>
            <section class="block">
                <div id="main" class="column span-18 border">
                    <div id="flash">
                        <?php
                        //flash messenger display location
                        if (count($this->messages) > 0) {
                            printf("<h3 id='flash'>%s</h3>", $this->messages[0]);
                        }
                        ?>
                    </div>
                    <?php echo $this->layout()->content; //placeholder for redering views ?>
                </div>
                <aside id="sidebar" class="column span-4 last">
                    <?php echo $this->layout()->search //custom placeholder ?>
                    <div id="subNav">
                        <?php echo $this->layout()->subNav //custom placeholder ?>
                    </div>
                    <div id="adminMenu">
                        <?php echo $this->layout()->adminMenu //custom placeholder ?>
                    </div>
                </aside>
            </section>
            <footer class="block">
                <div id="footer" class="column span-24">
                    <p>Created by <em>Your Name</em> with <a href="http://framework.zend.com/">Zend Framework. &COPY; </a></p>
                </div>
            </footer>
        </section>
    </body>
</html>
<?php echo $this->inlineScript() ?> //javascript includes at bottom of page

希望这有帮助。

答案 1 :(得分:2)

首先,你在一个似乎适合你的路由的方法中初始化布局 - 可能是一个坏主意。其次,如果您使用Zend_Application的完整堆栈,则可以使用提供的Zend_Application_Resource_Layout并将options设置为configuration

此外,您不希望使用原始include语句从布局文件中提取应使用$this->render('thetemplate.phtml')的内容。有关详细信息,请查看Zend_Layout Quickstart