Smarty模板类内部原理实例分析

时间:2022-07-27
本文章向大家介绍Smarty模板类内部原理实例分析,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

本文实例讲述了Smarty模板类内部原理。分享给大家供大家参考,具体如下:

之前在学习ThinkPHP的时候,有接触到Smarty模板类,但是一直不知道其内部实现的原理,博主今天终于知道了其内部原理,其实也挺简单的,然后写了一个迷你版的Smarty模板类,对理解其内部原理有了很大的帮助。

1、迷你版Smarty类

首先上代码,最后再进行讲解。

项目结构图

MiniSmarty类代码(MiniSmarty.class.php)

<?php
/**
 * 迷你模板类
 */
class MiniSmarty{
  public $template_dir = '';//模板文件放置的目录
  public $compile_dir = '';//编译后文件放置的目录
  public $tpl_var = array();//模板赋值的变量
  /**
   * 给模板进行赋值
   * @param str $key  键
   * @param mixed $value 值
   * @return void
   */
  public function assign($key,$value){
    $this- tpl_var[$key] = $value;
  }
  /**
   * 编译模板,并引入编译后的文件
   * @param str $template 模板文件
   * @return void
   */
  public function display($template){
    $compile_file = $this- compile($template);
    include($compile_file);
  }
  /**
   * 将模板文件编译成php文件
   * @param str $template 模板文件名
   * @return str      编译文件名
   */
  private function compile($template){
    $template_file = $this- template_dir.'/'.$template;
    //读取模板文件中的内容
    $source = file_get_contents($template_file);
    //判断是否需要再次生产编译文件
    $compile_file = $this- compile_dir.'/'.$template.'.php';
    //如果存在编译文件且编译文件的修改时间比模板文件大,则不用再次编译,直接返回文件路径
    if(file_exists($compile_file) && filemtime($compile_file)   filemtime($template_file)){
      return $compile_file;
    }
    //解析{$}为<?php echo 等操作
    $source = str_replace('{$', '<?php echo $this- tpl_var['', $source);
    $source = str_replace('}', ''];? ', $source);
    //生成编译文件
    file_put_contents($compile_file, $source);
    //返回编译后的文件路径
    return $compile_file;
  }
}
? 

测试模板类代码(testSmarty.php)

<?php
//1、引入并创建模板实例
include ('./MiniSmarty.class.php');
$Smarty = new MiniSmarty();
$Smarty- template_dir = './template';
$Smarty- compile_dir = './compile';
//2、给模板对象赋值
$title = '两会召开';
$content = '好奶粉,好会议,好新闻';
$Smarty- assign('title',$title);
$Smarty- assign('content',$content);
//3、显示模板
$template = 'template.html';
$Smarty- display($template);
? 

模板文件(template.html)

<!DOCTYPE html 
<html 
<head 
  <meta charset="utf-8" 
  <meta http-equiv="X-UA-Compatible" content="IE=edge" 
  <title {$title}</title 
  <link rel="stylesheet" href="" 
</head 
<body 
  <h3 {$content}</h3 
</body 
</html 

编译后的文件(template.html.php)

<!DOCTYPE html 
<html 
<head 
  <meta charset="utf-8" 
  <meta http-equiv="X-UA-Compatible" content="IE=edge" 
  <title <?php echo $this- tpl_var['title'];? </title 
  <link rel="stylesheet" href="" 
</head 
<body 
  <h3 <?php echo $this- tpl_var['content'];? </h3 
</body 
</html 

代码都贴完了,最后解释一下。在测试模板类(testSmarty.php)文件中,首先是引入模板类文件,实例化模板对象,然后给模板对象赋值,最后显示模板。在模板类(MiniSmarty.class.php)文件中,有3个属性和3个方法,属性分别是template_dir 、compile_dir‘和tpl_var,含义分别是模板文件的路径、编译后文件的路径、模板对象的变量。3个方法分别是assign、display和compile,assign方法是给模板对象赋值,display方法是编译模板文件,并引入(显示)编译后的文件,compile方法是编译模板文件。编译模板文件的过程主要是将模板文件中的{标签}解析成<?php echo

2、Smarty原理分析

工作流程

(1)把需要显示的全局变量,赋值,塞到对象的内部属性中的一个数组里 (2)然后编译模板,将{$标签}解析成相应的php echo 代码 (3)引入编译后的php文件

使用步骤

(1)Smarty是一个类,要使用的话,必须引入在进行实例化 (2)使用assign给模板赋值 (3)使用display方法【从编译到输出】

Smarty的缺点

(1)编译模板,浪费时间 (2)要把变量再重新赋值到对象的属性中,增大了开销