ホームページ php教程 PHP开发 Zend Framework は Zend_View 統合 Smarty テンプレート システム メソッドを実装します

Zend Framework は Zend_View 統合 Smarty テンプレート システム メソッドを実装します

Jan 03, 2017 pm 01:35 PM

この記事の例では、Zend Framework が Zend_View 統合 Smarty テンプレート システムを実装する方法を説明します。参考のために皆さんと共有してください。詳細は次のとおりです:

Zend_View は Zend_View_Interface を抽象化し、smarty などのさまざまなビュー ソリューションを統合できるようにします。他のビュー システムを Zend のビューとして使用するには、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 = &#39;Zend_View&#39;);
  /**
   * Add an additional path to view resources
   *
   * @param string $path
   * @param string $classPrefix
   * @return void
   */
  public function addBasePath($path, $classPrefix = &#39;Zend_View&#39;);
  /**
   * 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 の基本実装は次のとおりです:

smarty ダウンロード アドレス

http://www.smarty.net/files/Smarty-3.1.7.ta​​r.gz

ディレクトリ構造

root@coder-671T-M:/www/zf_demo1# ツリー
.
§── application
│ §── Bootstrap.php
│ っていつ── configs
│ │ └── application.ini
│ っています── コントローラ
│ │ §── ErrorController.php
│ │ └── IndexController.php
│ §── モデル
│ └── ビュー
│ っていつ── ヘルパー
│ └── スクリプト
│ っていつ── error
│ └── error.phtml
│ .
│ │ └─ 見る
│ │ └─ Smarty.php
│ └──smartylib
│ §── debug.tpl
│ §── プラグイン
│ │ §── .. ..................
│ │ └ ──variablefilter.htmlspecialchars.php
│ っていつ── SmartyBC.class.php
│ っていつ── Smarty .class.php
│ └── sysplugins
│ っていつ── …… ......
│ └──smarty_security.php
っていつ──public
│ └──index.php
っていつ──temp
│ └──smarty
│ └─ ─ templates_c
│ └─ 73d91bef3fca4e40520a7751b fdfb3e44b05bdbd.file.index.tpl.php
└─ テスト
っていつ ── アプリケーション
│ └─ コントローラー
│ └─ IndexControllerTest.php
§── bootstrap.php
っています── ライブラリ
└── phpunit.xml

24 ディレクトリ、13 4 ファイル

/zf_demo1/library/ Lq/View/Smarty.php

<?php
require_once &#39;smartylib/Smarty.class.php&#39;;
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 ( &#39;Invalid path provided&#39; );
  }
  /**
   * 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 = &#39;Zend_View&#39;) {
    return $this->setScriptPath ( $path );
  }
  /**
   * Alias for setScriptPath
   *
   * @param $path string
   * @param $prefix string
   *      Unused
   * @return void
   */
  public function addBasePath($path, $prefix = &#39;Zend_View&#39;) {
    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(&#39;/www/zf_demo1/application/views/scripts&#39;);
    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(&#39;viewRenderer&#39;)->setNoRender();
    $this->view = $this->getInvokeArg ( &#39;bootstrap&#39; )->getResource ( &#39;smarty&#39; );
    $this->view->book = &#39;Hello World! &#39;;
    $this->view->author = &#39;by smarty&#39;;
    $this->view->render(&#39;index/index.tpl&#39;);
  }
}
ログイン後にコピー

/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 ファイルを作成し、それに応じて設定します。たとえば

/**
* Initialize new Smarty object
*
*/
public function __construct()
{
    // selfpointer needed by some other class methods
    $this->smarty = $this;
    if (is_callable(&#39;mb_internal_encoding&#39;)) {
      mb_internal_encoding(Smarty::$_CHARSET);
    }
    $this->start_time = microtime(true);
    // set default dirs
    $this->setTemplateDir(&#39;/www/zf_demo1/temp/smarty&#39; . DS . &#39;templates&#39; . DS)
      ->setCompileDir(&#39;/www/zf_demo1/temp/smarty&#39; . DS . &#39;templates_c&#39; . DS)
      ->setPluginsDir(SMARTY_PLUGINS_DIR)
      ->setCacheDir(&#39;/www/zf_demo1/temp/smarty&#39; . DS . &#39;cache&#39; . DS)
      ->setConfigDir(&#39;/www/zf_demo1/temp/smarty&#39; . DS . &#39;configs&#39; . DS);
    $this->debug_tpl = &#39;file:&#39; . dirname(__FILE__) . &#39;/debug.tpl&#39;;
    if (isset($_SERVER[&#39;SCRIPT_NAME&#39;])) {
      $this->assignGlobal(&#39;SCRIPT_NAME&#39;, $_SERVER[&#39;SCRIPT_NAME&#39;]);
    }
}
ログイン後にコピー

この記事が PHP プログラミングのすべての人に役立つことを願っています。

Zend Framework が Zend_View 統合 Smarty テンプレート システムを実装する方法に関するその他の記事については、PHP 中国語 Web サイトに注目してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)