Yaf_Dispatcher::setView
(Yaf >=1.0.0)
Yaf_Dispatcher::setView — Définit un moteur de visualisation personnalisé
Description
Cette méthode fournit une solution si vous souhaitez utiliser un moteur de visualisation personnalisé au lieu de celui proposé par Yaf_View_Simple
Liste de paramètres
-
view
-
Une instance de la classe Yaf_View_Interface.
Valeurs de retour
Exemples
Exemple #1 Exemple avec Yaf_Dispatcher::setView()
<?php require "/path/to/smarty/Smarty.class.php"; class Smarty_Adapter implements Yaf_View_Interface { /** * Objet Smarty * @var Smarty */ public $_smarty; /** * Constructeur * * @param string $tmplPath * @param array $extraParams * @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; } } /** * Définit le chemin vers les templates * * @param string $path Le dossier à définir comme chemin. * @return void */ public function setScriptPath($path) { if (is_readable($path)) { $this->_smarty->template_dir = $path; return; } throw new Exception('Chemin invalide fourni'); } /** * Assigne une variable à une template * * @param string $key Le nom de la variable. * @param mixed $val La valeur de la variable. * @return void */ public function __set($key, $val) { $this->_smarty->assign($key, $val); } /** * Autorise l'utilisation de empty() et isset() * * @param string $key * @return boolean */ public function __isset($key) { return (null !== $this->_smarty->get_template_vars($key)); } /** * Autorise unset() sur des proporiétés d'objet * * @param string $key * @return void */ public function __unset($key) { $this->_smarty->clear_assign($key); } /** * Assigne les variables au template * * Autorise la définition d'une clé spécifique à une valeur spécifique, * OU le passage d'un tableau de clé=> valeur pour une définition en masse. * * @see __set() * @param string|array $spec La stratégie d'assignement à utiliser (clé our * tableau de clé=>valeur) * @param mixed $value (Optionnel) Si on assigne une variable nommée, utilise ce paramètre comme valeur. * @return void */ public function assign($spec, $value = null) { if (is_array($spec)) { $this->_smarty->assign($spec); return; } $this->_smarty->assign($spec, $value); } /** * Efface toutes les variables assignées * * Efface toutes les variables assignées à Yaf_View via * {@link assign()} ou en surchargeant la propriété * ({@link __get()}/{@link __set()}). * * @return void */ public function clearVars() { $this->_smarty->clear_all_assign(); } /** * Exécute un template et retourne le résultat. * * @param string $name The template to process. * @return string The output. */ public function render($name, $value = NULL) { return $this->_smarty->fetch($name); } public function display($name, $value = NULL) { echo $this->_smarty->fetch($name); } } ?>
Exemple #2 Exemple avec Yaf_Dispatcher::setView()
<?php class Bootstrap extends Yaf_Bootstrap_Abstract { /** * il y a quelques options de configuration pour smarty dans * la configuration : * * smarty.left_delimiter = "{{" * smarty.right_delimiter = "}}" * smarty.template_dir = APPLICATION_PATH "/views/scripts/" * smarty.compile_dir = APPLICATION_PATH "/views/templates_c/" * smarty.cache_dir = APPLICATION_PATH "/views/templates_d/" * */ public function _initConfig() { $config = Yaf_Application::app()->getConfig(); Yaf_Registry::set("config", $config); } public function _initLocalName() { /** nous plaçons la classe Smarty_Adapter dans le dossier local de bibliothèques */ Yaf_Loader::getInstance()->registerLocalNamespace('Smarty'); } public function _initSmarty(Yaf_Dispatcher $dispatcher) { $smarty = new Smarty_Adapter(null, Yaf_Registry::get("config")->get("smarty")); $dispatcher->setView($smarty); /* maintenant, le moteur de rendu Smarty devient le moteur de visualisation par défaut de Yaf */ } } ?>