手册 >> 模板引擎 >> 在SpeedPHP框架内使用Smarty

在SpeedPHP框架内使用Smarty

在SpeedPHP框架中使用Smarty模板引擎是非常容易的,并且sp框架提供了一些基于Smarty引擎的扩展功能,让我们可以更简单有效地使用Smarty来提高我们的开发效率。

这里我们并非一定要有使用Smarty的经验,从sp框架开始进行Smarty的学习和开发,是比较好的一个方法。

首先我们来配置一下我们的应用程序,使得它可以使用Smarty来开发。

$spConfig = array(
 ...
	'view' => array(
		'enabled' => TRUE, // 开启Smarty支持
		'config' =>array(
			'template_dir' => APP_PATH.'/tpl', // 模板页面所在的目录
			'compile_dir' => APP_PATH.'/tmp', // 临时文件编译目录
			'cache_dir' => APP_PATH.'/tmp', // 临时文件缓存目录
			'left_delimiter' => '<{',  // Smarty左限定符,默认是{
			'right_delimiter' => '}>', // Smarty右限定符,默认是}
		),
	),
 ...
		

上面我们需要配置的有三个目录:template_dir是模板页面所在的目录,Smarty将在该目录下面去寻找对应的页面模板;compile_dir是模板编译的临时文件目录,而cache_dir是临时文件缓存目录,因为都是临时文件,所以compile_dir和cache_dir放到一起方便管理。

由于Smarty会将compile_dir和cache_dir内的文件都生成了PHP文件,所以并不需要担心临时文件会存在的安全问题。

请注意,以上设置的三个目录,都必须是存在的目录!由于Smarty并不会自动建立目录,所以我们必须要把这些目录先建好,哪怕仅是空目录。

在正确配置之后,我们就可以开始在应用程序中使用Smarty了。

按照MVC的理念,我们最好仅在Control层去调用View层的视图,所以sp框架也限定了我们只能在controller内使用view的对象。

test.html 模板文件(存放在应用程序目录下的tpl目录,正如上面所配置的template_dir目录)

<html><head></head>
<body>
大家好,我是test.html。<br>
$sent_ok等于:<{$sent_ok}>
</body>
</html>		

在控制器中,

<?php
class main extends spController
{
 ...
function test(){
    $ok = "i am ok!";
	$this->sent_ok = $ok; // 赋值给模板,这里是将$ok的值赋给了模板中的sent_ok,所以在模板中调用将是<{$sent_ok}>
    $this->display('test.html'); // 显示模板
}
 ...
}		

访问test动作,结果:

大家好,我是test.html。

$sent_ok等于:i am ok!

从上面可以看到,使用$this->变量名的方法,可以对模板上的变量进行赋值。

而输出模板的方法,就是$this->display('模板文件名'); 

本章我们介绍在sp框架内进行Smarty模板开发的配置和初步的使用方法。下章我们将进一步了解Smarty的使用,同时还将介绍非常方便的自动模板输出和spView的高级功能。