Zend Framework實(shí)現(xiàn)Zend_View集成Smarty模板系統(tǒng)的方法
本文實(shí)例講述了Zend Framework實(shí)現(xiàn)Zend_View集成Smarty模板系統(tǒng)的方法。分享給大家供大家參考,具體如下:
Zend_View抽象出了Zend_View_Interface,可以讓我們集成不同的視圖解決方案,例如可以集成smarty。要在zend中使用其他視圖系統(tǒng)作為視圖,只要實(shí)現(xiàn)Zend_View_Interface接口即可。
Zend_View_Interface的接口定義:
<?php
/**
* Interface class for Zend_View compatible template engine implementations
*
* @category Zend
* @package Zend_View
* @copyright Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
interface Zend_View_Interface
{
/**
* Return the template engine object, if any
*
* If using a third-party template engine, such as Smarty, patTemplate,
* phplib, etc, return the template engine object. Useful for calling
* methods on these objects, such as for setting filters, modifiers, etc.
*
* @return mixed
*/
public function getEngine();
/**
* Set the path to find the view script used by render()
*
* @param string|array The directory (-ies) to set as the path. Note that
* the concrete view implentation may not necessarily support multiple
* directories.
* @return void
*/
public function setScriptPath($path);
/**
* Retrieve all view script paths
*
* @return array
*/
public function getScriptPaths();
/**
* Set a base path to all view resources
*
* @param string $path
* @param string $classPrefix
* @return void
*/
public function setBasePath($path, $classPrefix = 'Zend_View');
/**
* Add an additional path to view resources
*
* @param string $path
* @param string $classPrefix
* @return void
*/
public function addBasePath($path, $classPrefix = 'Zend_View');
/**
* Assign a variable to the view
*
* @param string $key The variable name.
* @param mixed $val The variable value.
* @return void
*/
public function __set($key, $val);
/**
* Allows testing with empty() and isset() to work
*
* @param string $key
* @return boolean
*/
public function __isset($key);
/**
* Allows unset() on object properties to work
*
* @param string $key
* @return void
*/
public function __unset($key);
/**
* Assign variables to the view script via differing strategies.
*
* Suggested implementation is to allow setting a specific key to the
* specified value, OR passing an array of key => value pairs to set en
* masse.
*
* @see __set()
* @param string|array $spec The assignment strategy to use (key or array of key
* => value pairs)
* @param mixed $value (Optional) If assigning a named variable, use this
* as the value.
* @return void
*/
public function assign($spec, $value = null);
/**
* Clear all assigned variables
*
* Clears all variables assigned to Zend_View either via {@link assign()} or
* property overloading ({@link __get()}/{@link __set()}).
*
* @return void
*/
public function clearVars();
/**
* Processes a view script and returns the output.
*
* @param string $name The script name to process.
* @return string The script output.
*/
public function render($name);
}
集成Smarty的基本實(shí)現(xiàn)如下:
smarty下載地址
http://www.smarty.net/files/Smarty-3.1.7.tar.gz
目錄結(jié)構(gòu)
root@coder-671T-M:/www/zf_demo1# tree
.
├── application
│ ├── Bootstrap.php
│ ├── configs
│ │ └── application.ini
│ ├── controllers
│ │ ├── ErrorController.php
│ │ └── IndexController.php
│ ├── models
│ └── views
│ ├── helpers
│ └── scripts
│ ├── error
│ │ └── error.phtml
│ └── index
│ ├── index.phtml
│ └── index.tpl
├── docs
│ └── README.txt
├── library
│ ├── Lq
│ │ └── View
│ │ └── Smarty.php
│ └── smartylib
│ ├── debug.tpl
│ ├── plugins
│ │ ├── ...........................
│ │ └── variablefilter.htmlspecialchars.php
│ ├── SmartyBC.class.php
│ ├── Smarty.class.php
│ └── sysplugins
│ ├── ..........................
│ └── smarty_security.php
├── public
│ └── index.php
├── temp
│ └── smarty
│ └── templates_c
│ └── 73d91bef3fca4e40520a7751bfdfb3e44b05bdbd.file.index.tpl.php
└── tests
├── application
│ └── controllers
│ └── IndexControllerTest.php
├── bootstrap.php
├── library
└── phpunit.xml
24 directories, 134 files
/zf_demo1/library/Lq/View/Smarty.php
<?php
require_once 'smartylib/Smarty.class.php';
class Lq_View_Smarty implements Zend_View_Interface {
/**
* Smarty object
*
* @var Smarty
*/
protected $_smarty;
/**
* Constructor
*
* @param $tmplPath string
* @param $extraParams array
* @return void
*/
public function __construct($tmplPath = null, $extraParams = array()) {
$this->_smarty = new Smarty ();
if (null !== $tmplPath) {
$this->setScriptPath ( $tmplPath );
}
foreach ( $extraParams as $key => $value ) {
$this->_smarty->$key = $value;
}
}
/**
* Return the template engine object
*
* @return Smarty
*/
public function getEngine() {
return $this->_smarty;
}
/**
* Set the path to the templates
*
* @param $path string
* The directory to set as the path.
* @return void
*/
public function setScriptPath($path) {
if (is_readable ( $path )) {
$this->_smarty->template_dir = $path;
return;
}
throw new Exception ( 'Invalid path provided' );
}
/**
* Retrieve the current template directory
*
* @return string
*/
public function getScriptPaths() {
return array ($this->_smarty->template_dir );
}
/**
* Alias for setScriptPath
*
* @param $path string
* @param $prefix string
* Unused
* @return void
*/
public function setBasePath($path, $prefix = 'Zend_View') {
return $this->setScriptPath ( $path );
}
/**
* Alias for setScriptPath
*
* @param $path string
* @param $prefix string
* Unused
* @return void
*/
public function addBasePath($path, $prefix = 'Zend_View') {
return $this->setScriptPath ( $path );
}
/**
* Assign a variable to the template
*
* @param $key string
* The variable name.
* @param $val mixed
* The variable value.
* @return void
*/
public function __set($key, $val) {
$this->_smarty->assign ( $key, $val );
}
/**
* Retrieve an assigned variable
*
* @param $key string
* The variable name.
* @return mixed The variable value.
*/
public function __get($key) {
return $this->_smarty->get_template_vars ( $key );
}
/**
* Allows testing with empty() and isset() to work
*
* @param $key string
* @return boolean
*/
public function __isset($key) {
return (null !== $this->_smarty->get_template_vars ( $key ));
}
/**
* Allows unset() on object properties to work
*
* @param $key string
* @return void
*/
public function __unset($key) {
$this->_smarty->clear_assign ( $key );
}
/**
* Assign variables to the template
*
* Allows setting a specific key to the specified value, OR passing an array
* of key => value pairs to set en masse.
*
* @see __set()
* @param $spec string|array
* The assignment strategy to use (key or array of key
* => value pairs)
* @param $value mixed
* (Optional) If assigning a named variable, use this
* as the value.
* @return void
*/
public function assign($spec, $value = null) {
if (is_array ( $spec )) {
$this->_smarty->assign ( $spec );
return;
}
$this->_smarty->assign ( $spec, $value );
}
/**
* Clear all assigned variables
*
* Clears all variables assigned to Zend_View either via {@link assign()} or
* property overloading ({@link __get()}/{@link __set()}).
*
* @return void
*/
public function clearVars() {
$this->_smarty->clear_all_assign ();
}
/**
* Processes a template and returns the output.
*
* @param $name string
* The template to process.
* @return string The output.
*/
public function render($name) {
ob_start();
echo $this->_smarty->fetch ( $name );
unset($name);
}
}
/zf_demo1/application/configs/application.ini
[production] includePaths.library = APPLICATION_PATH "/../library" bootstrap.path = APPLICATION_PATH "/Bootstrap.php" bootstrap.class = "Bootstrap" appnamespace = "Application" autoloadernamespaces.lq = "Lq_" pluginpaths.Lq_View_Smarty = "Lq/View/Smarty" resources.frontController.controllerDirectory = APPLICATION_PATH "/controllers" resources.frontController.params.displayExceptions = 1 phpSettings.display_startup_errors = 1 phpSettings.display_errors = 1
/zf_demo1/application/Bootstrap.php
<?php
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap {
/**
* Initialize Smarty view
*/
protected function _initSmarty() {
$smarty = new Lq_View_Smarty ();
$smarty->setScriptPath('/www/zf_demo1/application/views/scripts');
return $smarty;
}
}
/zf_demo1/application/controllers/IndexController.php
<?php
class IndexController extends Zend_Controller_Action {
public function init() {
/*
* Initialize action controller here
*/
}
public function indexAction() {
$this->_helper->getHelper('viewRenderer')->setNoRender();
$this->view = $this->getInvokeArg ( 'bootstrap' )->getResource ( 'smarty' );
$this->view->book = 'Hello World! ';
$this->view->author = 'by smarty';
$this->view->render('index/index.tpl');
}
}
/zf_demo1/application/views/scripts/index/index.tpl
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
{$book}
{$author}
</body>
</html>
如果需要配置smarty可以打開/zf_demo1/library/smartylib/Smarty.class.php文件進(jìn)行相應(yīng)配置例如
/**
* Initialize new Smarty object
*
*/
public function __construct()
{
// selfpointer needed by some other class methods
$this->smarty = $this;
if (is_callable('mb_internal_encoding')) {
mb_internal_encoding(Smarty::$_CHARSET);
}
$this->start_time = microtime(true);
// set default dirs
$this->setTemplateDir('/www/zf_demo1/temp/smarty' . DS . 'templates' . DS)
->setCompileDir('/www/zf_demo1/temp/smarty' . DS . 'templates_c' . DS)
->setPluginsDir(SMARTY_PLUGINS_DIR)
->setCacheDir('/www/zf_demo1/temp/smarty' . DS . 'cache' . DS)
->setConfigDir('/www/zf_demo1/temp/smarty' . DS . 'configs' . DS);
$this->debug_tpl = 'file:' . dirname(__FILE__) . '/debug.tpl';
if (isset($_SERVER['SCRIPT_NAME'])) {
$this->assignGlobal('SCRIPT_NAME', $_SERVER['SCRIPT_NAME']);
}
}
更多關(guān)于zend相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Zend FrameWork框架入門教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《Yii框架入門及常用技巧總結(jié)》、《ThinkPHP入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- Zend Framework教程之視圖組件Zend_View用法詳解
- Zend Framework處理Json數(shù)據(jù)方法詳解
- Zend Framework使用Zend_Loader組件動(dòng)態(tài)加載文件和類用法詳解
- Zend Framework入門教程之Zend_Registry組件用法詳解
- Zend Framework入門教程之Zend_Config組件用法詳解
- Zend Framework過(guò)濾器Zend_Filter用法詳解
- Zend Framework實(shí)現(xiàn)自定義過(guò)濾器的方法
- php入門教程之Zend Studio設(shè)置與開發(fā)實(shí)例
- Zend Framework開發(fā)入門經(jīng)典教程
- Zend Framework入門教程之Zend_View組件用法示例
相關(guān)文章
thinkphp中AJAX返回ajaxReturn()方法分析
這篇文章主要介紹了thinkphp中AJAX返回ajaxReturn()方法,結(jié)合實(shí)例形式分析了thinkPHP中ajax操作的功能、數(shù)據(jù)返回格式以及ajaxReturn方法的簡(jiǎn)單使用技巧,需要的朋友可以參考下2016-12-12
Yii2使用自帶的UploadedFile實(shí)現(xiàn)的文件上傳
這篇文章主要介紹了Yii2使用自帶的UploadedFile實(shí)現(xiàn)的文件上傳的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
php實(shí)現(xiàn)當(dāng)前頁(yè)面點(diǎn)擊下載文件的實(shí)例代碼
下面小編就為大家?guī)?lái)一篇php實(shí)現(xiàn)當(dāng)前頁(yè)面點(diǎn)擊下載文件的實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11
PHP中__autoload和Smarty沖突的簡(jiǎn)單解決方法
這篇文章主要介紹了PHP中__autoload和Smarty沖突的簡(jiǎn)單解決方法,通過(guò)spl_autoload_register注冊(cè)__autoload函數(shù)的方法來(lái)解決__autoload函數(shù)再在Smarty無(wú)效的問(wèn)題,需要的朋友可以參考下2016-04-04
大家須知簡(jiǎn)單的php性能優(yōu)化注意點(diǎn)
通過(guò)本文給大家介紹在什么情況下可能遇到性能問(wèn)題,php性能問(wèn)題的解決方向及優(yōu)化點(diǎn),對(duì)php性能優(yōu)化注意點(diǎn)相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01
PHP內(nèi)置函數(shù)生成隨機(jī)數(shù)實(shí)例
在本篇文章里小編給大家分享了關(guān)于PHP內(nèi)置函數(shù)生成隨機(jī)數(shù)實(shí)例內(nèi)容,對(duì)此有興趣的朋友們可以學(xué)習(xí)下。2019-01-01
php 數(shù)據(jù)結(jié)構(gòu)之鏈表隊(duì)列
這篇文章主要介紹了php 數(shù)據(jù)結(jié)構(gòu)之鏈表隊(duì)列的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-10-10
Yii框架 session 數(shù)據(jù)庫(kù)存儲(chǔ)操作方法示例
這篇文章主要介紹了Yii框架 session 數(shù)據(jù)庫(kù)存儲(chǔ)操作方法,結(jié)合實(shí)例形式分析了使用Yii框架session組件配置與數(shù)據(jù)庫(kù)存儲(chǔ)相關(guān)操作技巧,需要的朋友可以參考下2019-11-11
PHP 中提示undefined index如何解決(多種方法)
這篇文章主要介紹了PHP 中提示undefined index如何解決(多種方法)的相關(guān)資料,需要的朋友可以參考下2016-03-03

