


Create a simple template engine in php, php template engine_PHP tutorial
Jul 12, 2016 am 08:54 AMphp制作簡單模版引擎,php模版引擎
PHP模板引擎就是一個PHP類庫,使用它可以使PHP代碼和HTML代碼進行分離,使代碼的可讀性和維護性得到顯著提高。而且這樣做的好處是,讓美工專心設計HTML前臺頁面,程序員專心去寫PHP業(yè)務邏輯。因此,?;婧苓m合公司的Web開發(fā)團隊使用,使每個人都能發(fā)揮其特長
下面我們就來看看如何簡單的來實現(xiàn)php的模板引擎
parser.class.php
<?php /** * 模版解析類 */ class Parser { // 字段,接收模版文件內(nèi)容 private $_tpl; // 構造方法,獲取模版文件內(nèi)容 public function __construct($_tplFile) { if (! $this->_tpl = file_get_contents($_tplFile)) { exit('ERROR:模版文件讀取錯誤'); } } // 解析普通變量 private function parvar() { $_patten = '/<!--\s+\{\$([\w]+)\}\s+-->/'; if (preg_match($_patten,$this->_tpl)) { $this->_tpl = preg_replace($_patten, "<?php echo \$this->_vars['$1'];?>",$this->_tpl); } } //解析IF語句 private function parif(){ $_pattenif = '/<!--\s+\{if\s+\$([\w]+)\}\s+-->/'; $_pattenElse = '/<!--\s+\{else\}\s+-->/'; $_pattenEndif = '/<!--\s+\{\/if\}\s+-->/'; if (preg_match($_pattenif,$this->_tpl)) { if (preg_match($_pattenEndif,$this->_tpl)) { $this->_tpl = preg_replace($_pattenif,"<?php if (\$this->_vars['$1']){?>",$this->_tpl); $this->_tpl = preg_replace($_pattenEndif,"<?php } ?>",$this->_tpl); if (preg_match($_pattenElse,$this->_tpl)) { $this->_tpl = preg_replace($_pattenElse,"<?php }else{?>",$this->_tpl); } }else{ echo 'ERROR:IF語句沒有關閉!'; } } } //PHP注釋解析 private function parCommon(){ $_pattenCommon = '/<!--\s+\{#\}(.*)\{#\}\s+-->/'; if (preg_match($_pattenCommon,$this->_tpl)) { $this->_tpl = preg_replace($_pattenCommon,"<?php /* $1 */ ?>",$this->_tpl); } } //解析foreach語句 private function parForeach(){ $_pattenForeach = '/<!--\s+\{foreach\s+\$([\w]+)\(([\w]+),([\w]+)\)\}\s+-->/'; $_pattenForeachEnd = '/<!--\s+\{\/foreach\}\s+-->/'; $_pattenForeachValue = '/<!--\s+\{@([\w]+)\}\s+-->/'; if (preg_match($_pattenForeach,$this->_tpl)) { if (preg_match($_pattenForeachEnd,$this->_tpl)) { $this->_tpl = preg_replace($_pattenForeach, "<?php foreach (\$this->_vars['$1'] as \$$2=>\$$3) {?>", $this->_tpl); $this->_tpl = preg_replace($_pattenForeachEnd, "<?php }?>", $this->_tpl); if (preg_match($_pattenForeachValue, $this->_tpl)) { $this->_tpl = preg_replace($_pattenForeachValue,"<?php echo \$$1;?>",$this->_tpl); } }else{ echo 'ERROR:Foreach語句沒有關閉!'; } } } //解析include方法 private function parInclude(){ $_pattenInclude = '/<!--\s+\{include\s+file=\"([\w\.\-]+)\"\}\s+-->/'; if (preg_match($_pattenInclude,$this->_tpl,$_file,$_file)) { if (!file_exists($_file[1])||empty($_file)) { echo 'ERROR:包含文件出錯!'; } $this->_tpl = preg_replace($_pattenInclude,"<?php include '$1';?>",$this->_tpl); } } //解析系統(tǒng)變量方法 private function parConfig(){ $_pattenConfig = '/<!--\s+\{([\w]+)\}\s+-->/'; if (preg_match($_pattenConfig,$this->_tpl)) { $this->_tpl = preg_replace($_pattenConfig,"<?php echo \$this->_config['$1'];?>",$this->_tpl); } } // 對外公共方法 public function compile($_path) { // 解析模版文件 $this->parvar(); $this->parif(); $this->parForeach(); $this->parInclude(); $this->parCommon(); $this->parConfig(); // 生成編譯文件 if (! file_put_contents($_path, $this->_tpl)) { exit('ERROR:編譯文件生成錯誤!'); } } } ?>
Templates.class.php
<?php /** * 模版類 */ class Templates { //注入變量 private $_vars = array(); //保存系統(tǒng)變量數(shù)組字段 private $_config = array(); //創(chuàng)建一個構造方法,來檢測各個目錄是否存在 public function __construct() { if (! is_dir(TPL_DIR) || ! is_dir(TPL_C_DIR) || ! is_dir(CACHE) || !is_dir(CONFIG)) { echo 'ERROR:模版目錄或編譯目錄,緩存目錄不存在!自動創(chuàng)建!'."<br />"; if (!is_dir(TPL_DIR)) { mkdir(TPL_DIR); echo '模版目錄'.TPL_DIR.'建立'."<br />"; } if (!is_dir(TPL_C_DIR)) { mkdir(TPL_C_DIR); echo '編譯目錄'.TPL_C_DIR.'建立'."<br />"; } if (!is_dir(CACHE)) { mkdir(CACHE); echo '緩存目錄'.CACHE.'建立'."<br />"; } if (!is_dir(CONFIG)) { mkdir(CONFIG); echo '緩存目錄'.CONFIG.'建立'."<br />"; } exit(); } //保存系統(tǒng)變量 $_sxe = simplexml_load_file(CONFIG.'/config.xml'); $_tagLib = $_sxe->xpath('/root/taglib'); foreach ($_tagLib as $_tag) { $this->_config["$_tag->name"] = $_tag->value; } } //assign()方法,用于注入變量 public function assign($_var,$_value){ //$_var用于同步模版里的變量名 //$_value表示值 if (isset($_var)&&!empty($_var)) { $this->_vars[$_var] = $_value; }else{ exit('ERROR:設置模版變量!'); } } //display()方法 public function display($_file) { $_tplFile = TPL_DIR . $_file; // 判斷文件是否存在 if (! file_exists($_tplFile)) { echo 'ERROR:模版文件不存在!自動創(chuàng)建Index.tpl模版文件!'; file_put_contents($_tplFile,'Index'); exit(); } //生成編譯文件 $_path = TPL_C_DIR.md5($_file).'-'.$_file.'.php'; //緩存文件 $_cacheFile = CACHE.md5($_file).'-'.$_file.'.html'; //當?shù)诙芜\行相同文件,直接載入緩存文件 if (IS_CACHE) { //判斷緩存文件和編譯文件都存在 if (file_exists($_cacheFile)&&file_exists($_path)) { //判斷模版文件是否修改過 if (filemtime($_path)>=filemtime($_tplFile)&&filemtime($_cacheFile)>=filemtime($_path)) { include $_cacheFile; echo '<!--cache-->'; return; } } } //當編譯文件不存在或者文件發(fā)生改變則重新生成 if (!file_exists($_path)||filemtime($_path)<filemtime($_tplFile)) { require ROOT_PATH.'/Class/parser.class.php'; //構造方法是傳入模版文件地址 $_parser = new Parser($_tplFile); //傳入編譯文件地址 $_parser->compile($_path); } //載入編譯文件 include $_path; if (IS_CACHE) { //獲取緩沖區(qū)數(shù)據(jù) file_put_contents($_cacheFile,ob_get_contents()); //清楚緩沖區(qū) ob_end_clean(); //載入緩存文件 include $_cacheFile; } } } ?>
templates.php
<?php //設置字符編碼UTF-8 header('Content-Type:text/html;charset=utf-8'); //網(wǎng)站根目錄 define('ROOT_PATH',dirname(__FILE__)); //存放模版文件夾 define('TPL_DIR',ROOT_PATH.'/Templates/'); //編譯文件夾 define('TPL_C_DIR',ROOT_PATH.'/Templates_c/'); //緩存文件夾 define('CACHE',ROOT_PATH.'/Cache/'); //系統(tǒng)變量配置目錄 define('CONFIG',ROOT_PATH.'/Config/'); //是否開啟緩沖區(qū) define('IS_CACHE',false);//false //判斷是否需要開啟 IS_CACHE ? ob_start() : null; //引入模版類 require ROOT_PATH.'/Class/Templates.class.php'; //實例化模版類 $_tpl=new Templates(); $_tpl->display('index.tpl'); ?>
templates/index.tpl
<!DOCTYPE html> <html lang="zn-cn"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <meta name="description" content=""> <meta name="keywords" content=""> <meta name="author" content=""> <meta name="author" content=""> <title><!-- {WebName} --></title> <link rel="stylesheet" type="text/css" href="css/bootstrap.min.css"> <link rel="stylesheet" type="text/css" href="css/style.css"> </head> <body> <!-- {#}php注釋{#} --> <!-- {if $a} --> 123 <!-- {else} --> 321 <!-- {/if} --> <br /> <!-- {foreach $array(key,value)} --> <!-- {@key} -->...<!-- {@value} --><br /> <!-- {/foreach} --> 系統(tǒng)變量<!-- {WebName} --><br /> 普通變量<!-- {$name} --><br /> <script src="/js/jquery-2.2.1.min.js" type="text/javascript"></script> <script src="/js/bootstrap.min.js" type="text/javascript"></script> <script type="text/javascript"> </script> </body> </html>
config/config.xml
<?xml version="1.0" encoding="UTF-8"?> <root> <taglib> <name>WebName</name> <value>XXX網(wǎng)站</value> </taglib> </root>
您可能感興趣的文章:
- php smarty模版引擎中的緩存應用
- php smarty模版引擎中的緩存應用
- php smarty模版引擎中變量操作符及使用方法
- ThinkPHP模版引擎之變量輸出詳解

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

To merge two PHP arrays and keep unique values, there are two main methods. 1. For index arrays or only deduplication, use array_merge and array_unique combinations: first merge array_merge($array1,$array2) and then use array_unique() to deduplicate them to finally get a new array containing all unique values; 2. For associative arrays and want to retain key-value pairs in the first array, use the operator: $result=$array1 $array2, which will ensure that the keys in the first array will not be overwritten by the second array. These two methods are applicable to different scenarios, depending on whether the key name is retained or only the focus is on

exit() is a function in PHP that is used to terminate script execution immediately. Common uses include: 1. Terminate the script in advance when an exception is detected, such as the file does not exist or verification fails; 2. Output intermediate results during debugging and stop execution; 3. Call exit() after redirecting in conjunction with header() to prevent subsequent code execution; In addition, exit() can accept string parameters as output content or integers as status code, and its alias is die().

The rational use of semantic tags in HTML can improve page structure clarity, accessibility and SEO effects. 1. Used for independent content blocks, such as blog posts or comments, it must be self-contained; 2. Used for classification related content, usually including titles, and is suitable for different modules of the page; 3. Used for auxiliary information related to the main content but not core, such as sidebar recommendations or author profiles. In actual development, labels should be combined and other, avoid excessive nesting, keep the structure simple, and verify the rationality of the structure through developer tools.

There are two ways to create an array in PHP: use the array() function or use brackets []. 1. Using the array() function is a traditional way, with good compatibility. Define index arrays such as $fruits=array("apple","banana","orange"), and associative arrays such as $user=array("name"=>"John","age"=>25); 2. Using [] is a simpler way to support since PHP5.4, such as $color

When you encounter the prompt "This operation requires escalation of permissions", it means that you need administrator permissions to continue. Solutions include: 1. Right-click the "Run as Administrator" program or set the shortcut to always run as an administrator; 2. Check whether the current account is an administrator account, if not, switch or request administrator assistance; 3. Use administrator permissions to open a command prompt or PowerShell to execute relevant commands; 4. Bypass the restrictions by obtaining file ownership or modifying the registry when necessary, but such operations need to be cautious and fully understand the risks. Confirm permission identity and try the above methods usually solve the problem.

The way to process raw POST data in PHP is to use $rawData=file_get_contents('php://input'), which is suitable for receiving JSON, XML, or other custom format data. 1.php://input is a read-only stream, which is only valid in POST requests; 2. Common problems include server configuration or middleware reading input streams, which makes it impossible to obtain data; 3. Application scenarios include receiving front-end fetch requests, third-party service callbacks, and building RESTfulAPIs; 4. The difference from $_POST is that $_POST automatically parses standard form data, while the original data is suitable for non-standard formats and allows manual parsing; 5. Ordinary HTM

To safely handle PHP file uploads, you need to verify the source and type, control the file name and path, set server restrictions, and process media files twice. 1. Verify the upload source to prevent CSRF through token and detect the real MIME type through finfo_file using whitelist control; 2. Rename the file to a random string and determine the extension to store it in a non-Web directory according to the detection type; 3. PHP configuration limits the upload size and temporary directory Nginx/Apache prohibits access to the upload directory; 4. The GD library resaves the pictures to clear potential malicious data.

InPHP,variablesarepassedbyvaluebydefault,meaningfunctionsorassignmentsreceiveacopyofthedata,whilepassingbyreferenceallowsmodificationstoaffecttheoriginalvariable.1.Whenpassingbyvalue,changestothecopydonotimpacttheoriginal,asshownwhenassigning$b=$aorp
