手动开发PHP模板引擎 一 (35)

模板叫做TPL,模仿于smarty模板引擎。

我们所说的模板是Web模板,是主要由HTML标记组成的语言来编写的页面,但也有如何表示包含动态生成内容的方式(解析标签)。模板引擎是一种软件库,允许我们
从模板生成HTML代码,并指定要包含的动态内容。

1 模板引擎的特点:

1.鼓励分离:让更个系统的可读性和维护性得到提高。
2.促进分工:使得程序员和美工去专心处理自己的设计。
3.比PHP更容易解析:编译文件和缓存文件加载更快、占资源更少。

4.增加安全性:可限制模板设计师进行不安全的操作的能力避免误删误访问等。

2 模板引擎的产品:

PHP 有很多团队专门开发的模板引擎,比如Smarty、Heyes Templates Class、
FastTemplate 等等。这些模板引擎我们直接拿过来使用,就可以完全实现以上的诸多
特点。可是对于初学者来说,了解模板引擎的原理可以更加深刻的理解为什么要使用模
板。

3 TPL模板流程图

当我们自己创建模板引擎的时候,最大的好处就是从简。因为很多团队编写好的模板引擎,它的功能虽然很多很强大,安全性也很高。但缺点就是很多我们用不到,并且体积非常

的臃肿。

  

4.创建TPL模板引擎

  1.创建初始模板所需要的文件夹和文件

a) index.php主文件,用于编写业务逻辑。
b) template.inc.php模板初始化文件,用于初始模版信息。
c) templates目录存放所有的模板文件。
d) templates_c目录存放所有编译文件。
e) cache目录存放所有缓存文件。
f) includes目录存放所有的类文件。
g) config目录存放模板系统变量配置文件。

  2.网站根目录下的index.php文件代码

//设置编码为utf-8
header(‘Content-Type:text/html;charset=utf-8‘);
//网站根目录
define(‘ROOT_PATH‘,dirname(__FILE__));
//存放模板文件夹
define(‘TPL_DIR‘,ROOT_PATH.‘/templates/‘);
//编译文件夹
define(‘TPL_C_DIR‘,ROOT_PATH.‘/templates_c/‘);
//缓存文件夹
define(‘CACHE_DIR‘,ROOT_PATH.‘/cache/‘);

  3 includes文件夹下的Templates.class.php—增加判断目录是否存在方法

//创建一个构造方法
public function __construct() {
//验证一下目录是否存在
  if (!is_dir(TPL_DIR) || !is_dir(TPL_C_DIR) || !is_dir(CACHE_DIR)) {
    exit(‘ERROR:模板文件夹或者编译文件夹或者缓存文件夹没有创建!‘);
  }
}

  4 includes文件夹下的Templates.class.php—创建display()方法来载入.tpl模板文件

这个也是samrty里面的display原型方法

//将模板导入到php文件中
  public function display($_file) {
//设置模板文件的路径
  $_tplFile = TPL_DIR.$_file;
//判断模板文件是否存在
  if (!file_exists($_tplFile)) {
    exit(‘ERROR:模板文件不存在!‘);
  }
//设置编译文件的文件名
  $_parFile = TPL_C_DIR.md5($_file).$_file.‘.php‘;
//判断编译文件是否存在,模板文件是否修改过
  if (!file_exists($_parFile) || filemtime($_parFile) < filemtime($_tplFile)) {
//生成编译文件
  file_put_contents($_parFile,file_get_contents($_tplFile));
  }
//载入编译文件
  include $_parFile;
}
//引入模板类
require ROOT_PATH.‘/includes/Template.class.php‘;
//实例化模板类
$_tpl = new Template();
//载入index.tpl
$_tpl->display(‘index.tpl);

未完待续

时间: 2024-08-03 03:18:45

手动开发PHP模板引擎 一 (35)的相关文章

Node.js开发 ---- Jade 模板引擎使用

1.安装jade插件npm install jade 2.app.js[javascript] view plain copy 在CODE上查看代码片派生到我的代码片var express = require('express'); var http = require('http'); var app = express(); app.set('view engine', 'jade'); // 设置模板引擎 app.set('views', __dirname); // 设置模板相对路径(相

JavaScript学习总结(一)——延迟对象、跨域、模板引擎、弹出层、AJAX示例

JavaScript学习总结(一)--延迟对象.跨域.模板引擎.弹出层.AJAX示例 目录 一.AJAX示例 1.1.优点 1.2.缺点 1.3.jQuery AJAX示例 二.延迟对象(Deferred) 2.1.回调函数 2.2.deferred.done 三.跨域 3.1.什么是跨域 3.2.JSONP跨域 3.3.jQuery使用JSONP跨域 3.4.跨域资源共享(CORS) 3.5.小结 四.弹出层 五.模板引擎 5.1.Hello World 5.2.方法 5.3.与AJAX结合应

Javascript:自己写模板引擎

背景 因为JS没有提供“字符串插入”和“多行字符串”特性,传统的拼凑字符串容易出错.性能不高和不容易理解代码,为了应对这些问题,很多个人和团队开发了模板引擎,现在主流的JS框架几乎都提供此类功能了. 模板引擎的实现方式有很多种,此处介绍一种简单.灵活和强大的思路,该方式借鉴了 JSP(web 服务器最终将 JSP 页面转换为了 Servlet),编译后会把模板转换为一个方法. 这个实现只是为团队介绍模板引擎的原理,具体应用还需要选择成熟的开源实现. 实现 1 <!DOCTYPE html> 2

模板引擎和框架

模板引擎(这里特指用于Web开发的模板引擎)是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,用于网站的模板引擎就会生成一个标准的HTML文档. 框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架.前者是从应用方面而后者是从目的方面给出的定义.

Spring Boot模板引擎 (三)

1.web应用开发之模板引擎 1.1.spring boot的web应用开发,是基于spring mvc 1.2.Spring boot 在spring默认基础上,自动配置添加了以下特性: 包含了ContentNegotiatingViewResolver和BeanNameViewResolver beans. 对静态资源的支持,包括对WebJars的支持. 自动注册Converter,GenericConverter,Formatter beans. 对HttpMessageConverter

模板引擎原理及underscore.js使用

为什么要使用模板引擎 DOM结构简单,完全可以使用DOM方法创建DOM树.$("<td></td").appendTo(); 当页面比较复杂的时候,下面的程序中红色部分来自JSON中的数据: <div class="feeds-item hasImg" id="item-702635"> <p class="feeds-item-pic"> <a href="http:

SpringBoot 配置 Thymeleaf模板引擎

Thymeleaf模板引擎 什么是模板引擎 模板引擎(这里特指用于Web开发的模板引擎)是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,用于网站的模板引擎就会生成一个标准的HTML文档. 学习视频: http://www.itlaoqi.com/chapter/1688.html 源码地址: QQ群 814077650 , 群共享中自助下载 老齐的官网: itlaoqi.com (更多干货就在其中) Thymeleaf的特点 Thymeleaf优点 主流唯一的前后端通用

Node.js开发入门—使用jade模板引擎

在"Node.js开发入门--Express安装与使用"里,我们曾经使用express generator创建了一个HelloExpress网站,express工具为我们生成了基本的目录结构.模板.stylesheet.routers等.虽然那只是一个简单的HelloWorld类的小东西,可里面包含的内容还是有些多了,为了更好的理解Express所支持的jade模板引擎的用法,我们这次提供一个手动创建的小网站,可以显示来访者的IP,并对访问进行计数. 安装jade npm instal

Spring Boot基础教程8-web应用开发-模板引擎jsp

一.spring boot的web应用开发,是基于spring mvc 二.Spring boot 在spring默认基础上,自动配置添加了以下特性: 1.   包含了ContentNegotiatingViewResolver和BeanNameViewResolver beans. 2.   对静态资源的支持,包括对WebJars的支持. 3.   自动注册Converter,GenericConverter,Formatter beans. 4.   对HttpMessageConverte