正文实例陈诉了Yii框架布局文件的动态切换操作。分享给大家供我们参照他事他说加以侦查,具体如下:
正文实例陈说了Yii2框架视图操作及Layout的施用情势。分享给我们供大家参照他事他说加以考察,具体如下:
本文实例呈报了Zend
Framework教程之Zend_Layout构造帮手。分享给大家供大家参考,具体如下:
要是您看了底层Controller的源码和Module的源码,那么你就能够很纯熟的婉约结构切换了。
渲染视图
一、作用
1、在调整器中切换当前结商谈在措施中动态切换结构
1.大家在Default 调节器里做示范
布局的法力和模版的法力相像。能够认为是把网站通用、公共的部分拿出来作为通用的页面框架。举个例子叁在这之中坚的web页面,大概页面包车型地铁头和尾都以同一,不一致样的可能只是内容body部分不相同,能够把国有的片段做成模版。不只可以够升高开销作用,也为最后时期的珍视带给便利。
layout = "custom2"; $this->render('index',array( 'name' => '谭勇', 'age' => 22 )); }}?>
11],true);// //http://localhost/yiipro/web/default/index?id=11//// echo Url::base();// ///yiipro/web // 返回视图 return $this->render; }}
二、使用
在类属性中评释layout 会覆盖父类Controller 类中的layout
达到切换布局的目录。
return $this->render;
就是渲染视图
此处举四个轻易的事例。
竟然大家能够在模块文件中扬言布局
2.浏览器访谈
率先用zend studio创设七个主干的zend framework项目:layout_demo1
namespace appmodulesTestModule;use yiibaseModule;class TestModule extends Module{ //当前应用主题 private $theme = 'default'; public function init() { //控制器文件存放目录 $this->controllerNamespace = 'appmodulesTestModulecontrollers'; $dirname = dirname; //视图目录 $this->setViewPath($dirname . '/views/' . $this->theme . '/'); //生命布局名称 $this->layout = "common"; }}
views/default/index.php
├─.settings├─application│ ├─configs│ ├─controllers│ ├─models│ └─views│
├─helpers│ └─scripts│ ├─error│ └─index├─docs├─library├─public└─tests
├─application │ └─controllers └─library
接下来大家就在default核心下的layouts目录中去研究common.php布局了。
表明视图像和文字件要放在views/default 目录下。
1.加入layout功能:
越来越多关于Yii相关内容感兴趣的读者可查阅本站专项论题:《Yii框架入门及常用技艺计算》、《php杰出开垦框架总括》、《smarty模板入门功底教程》、《php面向对象程序设计入门教程》、《php字符串用法总计》、《php+mysql数据库操作入门教程》及《php不足为怪数据库操作手艺汇总》
3.怎么着向视图传递变量
使用配置文件/layout_demo2/application/configs/application.ini,参预如下配置
希望本文所述对我们基于Yii框架的PHP程序设计有所支持。
return $this->render('index',['username'=>'张三','age'=>22]);
resources.frontController.controllerDirectory = APPLICATION_PATH "/controllers"resources.frontController.params.displayExceptions = 0resources.layout.layoutPath = APPLICATION_PATH "/layouts/scripts/"[staging : production]
布局layout
2.应和的目录和布局模版文件
/layout_demo2/application/layouts/scripts/layout.phtml
yiibaseApplication::$layout = 'main'appmoduleadminModule::$layout = 'main';
├─application│ ├─configs│ ├─controllers│ ├─layouts│ │ └─scripts│
├─models│ └─views
不使用layout,在调整器中插手属性public $layout = false
或情势中动态修正$this->layout = false
。
也足以应用$this->renderPartial()
代替$this->render()
layout.html相近如下:
View/layout/default.php
my app header layout() -> content;?> header
layout() -> content;?>
1、在调控器中切换当前结商谈在艺术中动态切换构造,只怕页面包车型客车头和尾都以均等。大家要在Default调整器里应用这一个构造,写上:
是拾贰分主要的。表示此处为布局的源委,也便是会动态变化的地点。
public $layout = 'default';
www.localzend.com/layout_demo1/public/
更加多关于Yii相关内容感兴趣的读者可查阅本站专项论题:《Yii框架入门及常用能力总结》、《php非凡开荒框架计算》、《smarty模板入门底子教程》、《php面向对象程序设计入门教程》、《php字符串用法总结》、《php+mysql数据库操作入门教程》及《php布衣蔬食数据库操作工夫汇总》
变化的html源码如下
但愿本文所述对大家基于Yii框架的PHP程序设计有着扶助。
my app header a:link, a:visited { color: #0398CA; } span#zf-name { color: #91BE3F; } div#welcome { color: #FFFFFF; background-image: url(http://framework.zend.com/images/bkg_header.jpg); width: 600px; height: 400px; border: 2px solid #444444; overflow: hidden; text-align: center; } div#more-information { background-image: url(http://framework.zend.com/images/bkg_body-bottom.gif); height: 100%; } Welcome to the Zend Framework! This is your project's main page Helpful Links:
Zend Framework Website | Zend Framework Manual header
中档部分就是/layout_demo1/application/views/scripts/index/index.phtml的内容。
流入:能够经过zf的吩咐工具自动生成layout的安插和文件。
zf enable layout
三、配置
1.自定义存放地点和名称能够透过application.ini配置文件配置布局文件的贮存地点以致构造文件的名号,举例:
resources.layout.layoutPath = APPLICATION_PATH "/mylayouts/scripts"resources.layout.layout = "mylayout"
2.在action中使用layout对象
$layout = $this->_helper->layout();
$helper = $this->_helper->getHelper;$layout = $helper->getLayoutInstance();
能够由此如下格局禁用当前action使用布局形式
$layout->disableLayout();
$layout->setLayout;
来安装使用另三个结构文件
$layout->assign('headertitle', 'app title');$layout->somekey = "value"
3.别的获取layout对象的章程
$layout = Zend_Layout::getMvcInstance$layout = $bootstrap->getResource;
四、别的用法,实现原理
切切实实别的的行使办法能够参照
Zend_Layout_Controller_Action_Helper_Layout类,Zend_Layout_Controller_Plugin_Layout类Zend_View_Helper_Layout类无庸赘述。
setLayoutInstance; } else { /** * @see Zend_Layout */ require_once 'Zend/Layout.php'; $layout = Zend_Layout::getMvcInstance(); } if { $pluginClass = $layout->getPluginClass(); $front = $this->getFrontController(); if ($front->hasPlugin { $plugin = $front->getPlugin; $plugin->setLayoutActionHelper; } } } public function init() { $this->_isActionControllerSuccessful = false; } /** * Get front controller instance * * @return Zend_Controller_Front */ public function getFrontController() { if (null === $this->_frontController) { /** * @see Zend_Controller_Front */ require_once 'Zend/Controller/Front.php'; $this->_frontController = Zend_Controller_Front::getInstance(); } return $this->_frontController; } /** * Get layout object * * @return Zend_Layout */ public function getLayoutInstance() { if (null === $this->_layout) { /** * @see Zend_Layout */ require_once 'Zend/Layout.php'; if (null === ($this->_layout = Zend_Layout::getMvcInstance { $this->_layout = new Zend_Layout(); } } return $this->_layout; } /** * Set layout object * * @param Zend_Layout $layout * @return Zend_Layout_Controller_Action_Helper_Layout */ public function setLayoutInstance { $this->_layout = $layout; return $this; } /** * Mark Action Controller (according to this plugin) as Running successfully * * @return Zend_Layout_Controller_Action_Helper_Layout */ public function postDispatch() { $this->_isActionControllerSuccessful = true; return $this; } /** * Did the previous action successfully complete? * * @return bool */ public function isActionControllerSuccessful() { return $this->_isActionControllerSuccessful; } /** * Strategy pattern; call object as method * * Returns layout object * * @return Zend_Layout */ public function direct() { return $this->getLayoutInstance(); } /** * Proxy method calls to layout object * * @param string $method * @param array $args * @return mixed */ public function __call { $layout = $this->getLayoutInstance(); if (method_exists { return call_user_func_array(array, $args); } require_once 'Zend/Layout/Exception.php'; throw new Zend_Layout_Exception(sprintf("Invalid method '%s' called on layout action helper", $method)); }}
setLayout; } } /** * Retrieve layout object * * @return Zend_Layout */ public function getLayout() { return $this->_layout; } /** * Set layout object * * @param Zend_Layout $layout * @return Zend_Layout_Controller_Plugin_Layout */ public function setLayout { $this->_layout = $layout; return $this; } /** * Set layout action helper * * @param Zend_Layout_Controller_Action_Helper_Layout $layoutActionHelper * @return Zend_Layout_Controller_Plugin_Layout */ public function setLayoutActionHelper(Zend_Layout_Controller_Action_Helper_Layout $layoutActionHelper) { $this->_layoutActionHelper = $layoutActionHelper; return $this; } /** * Retrieve layout action helper * * @return Zend_Layout_Controller_Action_Helper_Layout */ public function getLayoutActionHelper() { return $this->_layoutActionHelper; } /** * postDispatch() plugin hook -- render layout * * @param Zend_Controller_Request_Abstract $request * @return void */ public function postDispatch(Zend_Controller_Request_Abstract $request) { $layout = $this->getLayout(); $helper = $this->getLayoutActionHelper(); // Return early if forward detected if (!$request->isDispatched() || $this->getResponse || ($layout->getMvcSuccessfulActionOnly && !$helper->isActionControllerSuccessful { return; } // Return early if layout has been disabled if ) { return; } $response = $this->getResponse(); $content = $response->getBody; $contentKey = $layout->getContentKey(); if (isset { $content[$contentKey] = $content['default']; } if ('default' != $contentKey) { unset; } $layout->assign; $fullContent = null; $obStartLevel = ob_get_level(); try { $fullContent = $layout->render(); $response->setBody; } catch { while > $obStartLevel) { $fullContent .= ob_get_clean(); } $request->setParam('layoutFullContent', $fullContent); $request->setParam('layoutContent', $layout->content); $response->setBody; throw $e; } }}
_layout) { require_once 'Zend/Layout.php'; $this->_layout = Zend_Layout::getMvcInstance(); if (null === $this->_layout) { // Implicitly creates layout object $this->_layout = new Zend_Layout(); } } return $this->_layout; } /** * Set layout object * * @param Zend_Layout $layout * @return Zend_Layout_Controller_Action_Helper_Layout */ public function setLayout { $this->_layout = $layout; return $this; } /** * Return layout object * * Usage: $this->layout()->setLayout; * * @return Zend_Layout */ public function layout() { return $this->getLayout(); }}
越多关于zend相关内容感兴趣的读者可查阅本站专题:《Zend
FrameWork框架入门教程》、《php优异开辟框架总计》、《Yii框架入门及常用能力总括》、《ThinkPHP入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php平淡无奇数据库操作技巧汇总》
盼望本文所述对我们PHP程序设计有着扶持。
www.2979.com, 之家, 使用方法, 布局, 示例, 脚本, 视图, 详解