新随笔  :: 联系 :: 订阅 订阅  :: 管理

Smarty 学习笔记一 安装与使用

Posted on 2012-05-16 17:08  张贺  阅读(3575)  评论(0编辑  收藏  举报

一、安装
注:这里所使用的Smarty是3.x版本,要求PHP版本为5.2或者更高。
解压下载下来的Smarty压缩文件,将文件里lib目录下的所有文件复制到项目中的指定目录中,例如"/lib/Smarty/"目录下,在项目中引入"Smarty.class.php"文件后既可使用。
在Smarty内部会自动定义一个名为SMARTY_DIR的常量,该常量默认指向Smarty.class.php所在的绝对路径,可以通过自行设定该值来改变默认值,如:define('SMARTY_DIR', 
'/lib/smarty/')注:SMARTY_DIR常量必须以'/'结尾。

1 //直接引入smarty文件
2 require_once 'lib/smarty/Smarty.class.php';
3 //或通过定义SMARTY_DIR常量引入文件
4 define('SMARTY_DIR', 'lib/smarty/');
5 require_once SMARTY_DIR . 'Smarty.class.php';
6  
7 //实例化一个Smarty对象
8 $smarty = new Smarty(); 

在正式使用smarty之前,还需要设定几个基本路径:

  • $template_dir 用于存放smarty模版文件,如果未指定该路径,Smarty会自动在当前目录中寻找模版文件。
  • $compile_dir 用于存放smarty编译后的文件,如果不指定该目录,Smarty会自动在当前脚本所在目录下生成一个名为'templates_c'的目录用于存放生成的编译文件。
  • $config_dir 用于存放smarty配置文件
  • $cache_dir 用于存放smarty缓存文件,如果开启Smarty缓存功能,但没有指定该目录,Smarty会自动在当前脚本所在目录下生成一个名为'cache'的目录用于存放缓存文件。
1 $smarty->template_dir = 'views/';
2 $smarty->compile_dir = 'lib/smarty/templates_c/';
3 $smarty->config_dir = 'lib/smarty/configs/';
4 $smarty->cache_dir = 'lib/smarty/cache/';
5 //或者
6 $smarty->setTemplateDir(''views/';');
7 $smarty->setCompileDir('lib/smarty/templates_c/');
8 $smarty->setConfigDir('lib/smarty/configs/');
9 $smarty->setCacheDir('lib/smarty/cache/');

配置完成后,可通过Smarty的testInstall()内置方法查看配置信息:

1 $smarty->testInstall();

 

二、使用Smarty
Smarty配置完成以后,既可通过Smarty调用指定模版,首先在模版文件路径下(这里是'view/')创建一个模版文件home.tpl,内容如下:

 1 <html>
 2    <head>
 3      <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> 
 4      <title>Home</title> 
 5      <link rel="stylesheet" href="/css/master.css" type="text/css" media="screen" title="no title" charset="utf-8" />
 6    </head>
 7    <body>
 8      Smarty
 9    </body>
10 </html>

 

注:模版文件可以是任意后缀名,为了安全 起见,尽量避免使用.html、.php等可以直接被浏览器解析的文件,当然最好的办法是禁止web浏览器直接访问模版所在文件夹。
模版的调用
通过Smarty的内置方法display()来打开一个模版文件
void display(string templatestring cache_idstring compile_id);
对与上述方法中涉及到的参数,将会在后面介绍

1 $smarty->display(home.tpl);

变量的传递与访问
同时Smarty也可以通过内置方法assign()向模版文件中传递各种变量,如数值、字符串、数组、对象等。
void assign(string varnamemixed var,  bool nocache);
对与上述方法中涉及到的参数,将会在后面介绍

1 $arr1 = new Array('zh', '26');
2 $arr2 = new Array('name'=>'zh', 'age'=>26);
3 $obj = new MyObject();//MyObject为自定义类,包含name等公共属性
4 $smarty->assign('str', 'zh');//字符串
5 $smarty->assign('num', 6);//数值型
6 $smarty->assign('arr1', $arr1);//索引数组1
7 $smarty->assign('arr2', $arr2);//关联数组2
8 $smarty->assign('obj', $obj);//对象 

模版中使用变量:
在模版中调用变量,通过在变量之前加上$,并使用'{}'边界符将变量括起来,如home.tpl内容如下:

1 <body>
2     {$str} <!-- 输出zh -->
3     {$num} <!-- 输出zh -->
4     {$arr1[0]} <!-- 输出zh -->
5     {$arr2.name} <!-- 输出zh -->
6     {$obj->name} <!-- 输出zh -->
7 </body> 

可以看出,Smarty访问通过指定数组的索引来访问索引数组,通过'.'访问关联数组,通过'->'访问对象属性。
注:默认情况下,左边界符'{'与变量之间不能存在空格,否则变量将不会被解析,而是连同'{' 和 '}'原样显示出来。可以通过设置$smarty->auto_literal = false;来禁止这种 
行为。
'{}'是Smarty的默认边界符,可以通过修改$left_delimiter$right_delimiter属性来修改默认边界符,如:

1 $smarty->left_delimiter = '<{';
2 $smarty->right_delimiter = '}>';

Smarty支持模版内部注释,通过使用'{**}',如:{*这里是注释*}。Smarty中的注释与HTML注释<!-- -->有些不同,Smarty中的注释,并不会显示在网页源文件中。
注:如果修改了Smarty的默认边界符,相应的注释标签也需要变动,如<{*注释*}>,而且以下所有标签边界符均改为该种形式。
有时可能需要模版忽略变量的解析,而将原文显示出来,如:要在页面中显示出<{$name}>,而不是将$name的变量值显示出来,可以通过<{ldelim}> <{rdelim}>  <{$smarty.ldelim}> <{$smarty.rdelim}>来实现,如:

<{ldelim}>$name<{rdelim}>
<{$smarty.ldelim}>$name<{$smarty.ldelim}>

 

另一种方法是通过使用Smarty内置块标签<{literal}>,Smarty将会忽略解析出现在该标签之间的所有内容,如:

1 <{literal}>
2 这里输入不想被Smarty解析的内容
3 <{/literal}>

 

引号
与PHP类似,Smarty会解析出现在双引号中的变量,但该变量只能包含数字、字符和下划线,如果包含其它字符,则必须使用"`"(ESC键)将变量包含起来

 1 <{* $tpl_name将会别当作变量解析 *}>
 2 <{include file="subdir/$tpl_name.tpl"}>
 3  
 4 <{* 不会解析任何变量,只有双引号括起来的变量才会别解析 *}>
 5 <{include file='subdir/$tpl_name.tpl'}>
 6  
 7 <{* $smarty.config.myva将会别解析 *}>
 8 <{cycle values="one,two,`$smarty.config.myval`"}>
 9  
10 <{* $module.contact将会别解析 *}>
11 <{include file="`$module.contact`.tpl"}>
12  
13 <{* $module.$view都将会被解析 *}>
14 <{include file="`$module.$view`.tpl"}>

 

数学表达式
Smarty支持在模版中直接使用数学表达式,如:

 1 <{$foo+1}>
 2 
 3 <{$foo*$bar}>
 4 
 5 <{* some more complicated examples *}>
 6 
 7 <{$foo->bar-$bar[1]*$baz->foo->bar()-3*7}>
 8 
 9 <{if ($foo+$bar.test%$baz*134232+10+$b+10)}>
10 
11 <{$foo|truncate:"`$fooTruncCount/$barTruncFactor-1`"}>
12 
13 <{assign var="foo" value="`$foo+$bar`"}>

但并不推荐使用这种方式,应当将更多的逻辑判断放到逻辑业务层中去处理。