Inhaltsverzeichnis
模板基本使用
1. 模板配置
2. 使用模板
3. View API使用
4. default的模板标签
5. simple模板标签
模板高级使用
1. 自定义标签
2. layout布局
3. 模板主题
4. 编译机制
Heim Backend-Entwicklung PHP-Tutorial InitPHP框架搭建高可用WEB应用03:模板View使用_PHP教程

InitPHP框架搭建高可用WEB应用03:模板View使用_PHP教程

Jul 13, 2016 am 10:42 AM
搭建 框架

 

模板基本使用

1. 模板配置

我们继续之前几篇文章的代码设计。这一节主要讲如何来使用InitPHP框架的模板。

先看一下配置,配置文件从initphp/initphp.conf.php中的模板配置拷贝到conf/comm.conf.php文件中。模板的配置看如下:

/*********************************View配置*****************************************/
/**
 * 模板配置
 * 1. 可以自定义模板的文件夹,编译模板路径,模板文件后缀名称,编译模板后缀名称
 * 是否编译,模板的驱动和模板的主题
 * 2. 一般情况下,默认配置是最优的配置方案,你可以不选择修改模板文件参数
 */
$InitPHP_conf['template']['template_path']      = 'web/template'; //模板路径
$InitPHP_conf['template']['template_c_path']    = 'data/template_c'; //模板编译路径 
$InitPHP_conf['template']['template_type']      = 'htm'; //模板文件类型  
$InitPHP_conf['template']['template_c_type']    = 'tpl.php';//模板编译文件类型 
$InitPHP_conf[&#39;template&#39;][&#39;template_tag_left&#39;]  = &#39;<!--{';//模板左标签
$InitPHP_conf['template']['template_tag_right'] = '}-->&#39;;//模板右标签
$InitPHP_conf[&#39;template&#39;][&#39;is_compile&#39;]         = true;//模板每次编译-系统上线后可以关闭此功能
$InitPHP_conf[&#39;template&#39;][&#39;driver&#39;]             = &#39;simple&#39;; //不同的模板驱动编译
$InitPHP_conf[&#39;template&#39;][&#39;theme&#39;]              = &#39;&#39;; //模板主题
Nach dem Login kopieren

配置文件中已经有了详细的注释,这边要注意一下几个配置细节:

is_compile参数。一般情况下,模板都会写在template_path文件夹下,然后会生成新的编译文件到template_c_path文件夹下。在调试环境下打开这个参数,上线之后请关闭这个参数,这样每次请求都不会生成新的文件。

driver 参数。这个参数是模板驱动,默认有两种,第一种是default 第二种是simple,默认是simple

2. 使用模板

在web/目录下创建 template文件夹,主要用来存放模板,模板后缀名.htm

\

在app/目录下创建data/template_c文件夹,data文件夹主要用来存放生成的模板文件,这个文件需要有可写777权限。

\

在template下面创建一个hello.htm的模板文件

\

然后在indexController中调用模板

<!--?php
/**
 * 入口Controller
 * @author zhuli.zhul
 *
 */
class indexController extends Controller {
	
	public $initphp_list = array(get); //Action白名单
	
	public function before() {
		echo before<br/-->;
	}
	
	public function after() {
		echo after
;
	}
	
	/**
	 * 入口
	 */
	public function run() {
		$this->view->display(hello); //调用hello.htm模板,后缀名.htm不需要填写
	}
	
	/**
	 * get方法
	 */
	public function get() {
		echo THIS IS GET
;
	}
}
Nach dem Login kopieren

浏览器中访问http://127.0.0.1/test/www.initphp.com/ 后可以看到模板调用过,并且模板编译文件夹下多了一个新的文件hello.tpl.php

\

3. View API使用

View Api 一共只有5个API接口。接口文档:http://www.initphp.com/6_4.htm

模板API使用:

		//模板会按照顺序设置,但是set_tpl函数中的第二个参数F和L分别让模板最先和最后显示
		$this->view->set_tpl(&#39;test&#39;); //设置一个template/test.htm的模板页面
		$this->view->set_tpl(&#39;user/userinfo&#39;); //设置template/user/userinfo.htm
		$this->view->set_tpl(&#39;header&#39;, &#39;F&#39;); //设置为头部,最先显示
		$this->view->set_tpl(&#39;footer&#39;, &#39;L&#39;); //最后显示
		$this->view->remove_tpl(&#39;test&#39;); //可以移除上面已经设置的test.htm模板
		$this->view->get_tpl(); //可以得到已经设置的模板数组
		$this->view->display(); //模板显示
Nach dem Login kopieren

4. default的模板标签

default模板标签其实就是最原始的PHP使用方法,简单暴力好用。

/* 以下是default的模板标签使用方法(具体使用和PHP中一样):*/
/* 配置文件修改:*/
$InitPHP_conf[&#39;template&#39;][&#39;driver&#39;]             = &#39;default&#39;;

/* 一个简单的模板*/
<!--{echo $uid;}--> //这个输出一个变量
<!--{if (true == true) { }-->
<!--{}}-->
<!--{layout:user}--> 
Nach dem Login kopieren

5. simple模板标签

/* 以下是simple的模板标签使用方法:*/

/* 配置文件修改: */
$InitPHP_conf[&#39;template&#39;][&#39;driver&#39;]             = &#39;simple&#39;;

/* 标签使用方法: */

/* 普通使用方法:*/
<!--{echo $uid;}-->

/* if语句使用:*/
<!--{if ($a == 'yes')}-->
<!--{elseif ($a == 'no')}-->
<!--{else}-->
<!--{/if}--> 

/* foreach语句使用:*/
<!--{foreach ($a as $k => $V)}-->
<!--{/foreach}-->

/* for语句使用:*/
<!--{for ($i=0; $i<100; $i++)}-->
<!--{/for}--> 

/* 输出变量:*/
<!--{$username}-->

/* 输出常量:*/
<!--{APP_PATH}-->

<!--{layout:user}--> 
Nach dem Login kopieren

模板高级使用

1. 自定义标签

自定义的模板标签放置在: initphp/core/view/driver/文件夹下,该文件夹下已经有 default.init.php 和 simple.init.php,分别为default和simple两个模板标签驱动。文件的名称为:标签驱动名称+'.init.php',例如:simple.init.php类名称为:标签驱动名称+'Init',例如:simpleInit需要定义一个init($str, $left, $right)的公有函数,$str是需要替换的HTML代码,$left是模板标签的左标记(默认:'')需要使用自定义模板标签的时候,别忘记修改配置文件中的:$InitPHP_conf['template']['driver']

具体参看下面的simple模板标签驱动:

if (!defined(&#39;IS_INITPHP&#39;)) exit(&#39;Access Denied!&#39;);
/*********************************************************************************
 * InitPHP 2.1 国产PHP开发框架  View-simple 简单模板驱动规则模型
 *-------------------------------------------------------------------------------
 * 版权所有: CopyRight By initphp.com
 * 您可以自由使用该源码,但是在使用过程中,请保留作者信息。尊重他人劳动成果就是尊重自己
 *-------------------------------------------------------------------------------
 * $Author:zhuli
 * $Dtime:2011-10-09 
***********************************************************************************/
class simpleInit {

	/**
	 * 模板驱动-简单的驱动
	 * @param  string $str 模板文件数据
	 * @return string
	 */
	 public function init($str, $left, $right) {
	 	//if操作
	 	$str = preg_replace( /.$left.ifs+(.+?).$right./, , $str );
		$str = preg_replace( /.$left.else.$right./, , $str );
		$str = preg_replace( /.$left.elseifs+(.+?).$right./, , $str );
		//for操作
		$str = preg_replace(/.$left.fors+(.+?).$right./,,$str);
		$str = preg_replace(/.$left./for.$right./,,$str);
		//foreach操作
		$str = preg_replace(/.$left.foreachs+(.+?).$right./,,$str);
		$str = preg_replace(/.$left./foreach.$right./,,$str);
		//输出变量
		$str = preg_replace( /.$left.(\$[a-zA-Z_-&yuml;][a-zA-Z0-9_-&yuml;]*).$right./, , $str );
		//常量输出
		$str = preg_replace( /.$left.([A-Z_-&yuml;][A-Z0-9_-&yuml;]*).$right./s, , $str );
		//标签解析
		$str = preg_replace ( /.$left./if.$right./, , $str );
	 	$pattern = array(&#39;/&#39;.$left.&#39;/&#39;, &#39;/&#39;.$right.&#39;/&#39;);
		$replacement = array(&#39;&#39;);
		return preg_replace($pattern, $replacement, $str);
	 }
}
Nach dem Login kopieren

2. layout布局

模板HTML页面中使用Layout:。规则:左标签+'layout:'+'模板名称(不需要带.htm,有目录则user/version,和set_tpl()一样使用)'+右标签Layout是为了解决用户在HTML页面中来实现模板布局,html中使用了,则会显示version.htm静态页面

/* 模板布局,在所有模板引擎中该方法都通用 */
/* 模板布局主要是为了解决模板切割成多个小模板,模板中能直接调用使用*/
/* 标签使用:layout:模板名称(不需要带模板名称后缀,例如user.htm模板,则直接user。如果模板有多个文件夹,则test/user 代表test/user.htm模板)*/
<!--{layout:user}--> 
Nach dem Login kopieren

 

 

 

3. 模板主题

 

一般情况下,一个网站会有多个模板主题,InitPHP提供了简单的模板主题配置方法用户只需要配置$InitPHP_conf['template']['theme']这个变量,如果是red的主题,则值为'red'模板主题都是放在模板默认的目录下面的,例如'red'主题,则模板文件夹目录为: template/red/文件夹下实际上只是在模板默认的文件目录下再添加了一层目录,这样可以方便多主题的应用

 

 

 

 

4. 编译机制


InitPHP的模板机制都会将HTML页面编译成.php文件,默认为(template_c/编译文件夹和.tpl.php后缀名称)$InitPHP_conf['template']['is_compile']是否开启编译机制,建议开发的时候开启,开发完成上线后,关闭该参数

 


 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/635032.htmlTechArticle模板基本使用 1. 模板配置 我们继续之前几篇文章的代码设计。这一节主要讲如何来使用InitPHP框架的模板。 先看一下配置,配置文件从in...
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So bewerten Sie die Kosteneffizienz der kommerziellen Unterstützung für Java-Frameworks So bewerten Sie die Kosteneffizienz der kommerziellen Unterstützung für Java-Frameworks Jun 05, 2024 pm 05:25 PM

Die Bewertung des Kosten-/Leistungsverhältnisses des kommerziellen Supports für ein Java-Framework umfasst die folgenden Schritte: Bestimmen Sie das erforderliche Maß an Sicherheit und Service-Level-Agreement-Garantien (SLA). Die Erfahrung und das Fachwissen des Forschungsunterstützungsteams. Erwägen Sie zusätzliche Services wie Upgrades, Fehlerbehebung und Leistungsoptimierung. Wägen Sie die Kosten für die Geschäftsunterstützung gegen Risikominderung und Effizienzsteigerung ab.

Wie ist die Lernkurve von PHP-Frameworks im Vergleich zu anderen Sprach-Frameworks? Wie ist die Lernkurve von PHP-Frameworks im Vergleich zu anderen Sprach-Frameworks? Jun 06, 2024 pm 12:41 PM

Die Lernkurve eines PHP-Frameworks hängt von Sprachkenntnissen, Framework-Komplexität, Dokumentationsqualität und Community-Unterstützung ab. Die Lernkurve von PHP-Frameworks ist im Vergleich zu Python-Frameworks höher und im Vergleich zu Ruby-Frameworks niedriger. Im Vergleich zu Java-Frameworks haben PHP-Frameworks eine moderate Lernkurve, aber eine kürzere Einstiegszeit.

Wie wirken sich die Lightweight-Optionen von PHP-Frameworks auf die Anwendungsleistung aus? Wie wirken sich die Lightweight-Optionen von PHP-Frameworks auf die Anwendungsleistung aus? Jun 06, 2024 am 10:53 AM

Das leichte PHP-Framework verbessert die Anwendungsleistung durch geringe Größe und geringen Ressourcenverbrauch. Zu seinen Merkmalen gehören: geringe Größe, schneller Start, geringer Speicherverbrauch, verbesserte Reaktionsgeschwindigkeit und Durchsatz sowie reduzierter Ressourcenverbrauch. Praktischer Fall: SlimFramework erstellt eine REST-API, nur 500 KB, hohe Reaktionsfähigkeit und hoher Durchsatz

Leistungsvergleich von Java-Frameworks Leistungsvergleich von Java-Frameworks Jun 04, 2024 pm 03:56 PM

Laut Benchmarks sind Quarkus (schneller Start, geringer Speicher) oder Micronaut (TechEmpower ausgezeichnet) für kleine, leistungsstarke Anwendungen die ideale Wahl. SpringBoot eignet sich für große Full-Stack-Anwendungen, weist jedoch etwas langsamere Startzeiten und Speichernutzung auf.

Best Practices für die Dokumentation des Golang-Frameworks Best Practices für die Dokumentation des Golang-Frameworks Jun 04, 2024 pm 05:00 PM

Das Verfassen einer klaren und umfassenden Dokumentation ist für das Golang-Framework von entscheidender Bedeutung. Zu den Best Practices gehört die Befolgung eines etablierten Dokumentationsstils, beispielsweise des Go Coding Style Guide von Google. Verwenden Sie eine klare Organisationsstruktur, einschließlich Überschriften, Unterüberschriften und Listen, und sorgen Sie für eine Navigation. Bietet umfassende und genaue Informationen, einschließlich Leitfäden für den Einstieg, API-Referenzen und Konzepte. Verwenden Sie Codebeispiele, um Konzepte und Verwendung zu veranschaulichen. Halten Sie die Dokumentation auf dem neuesten Stand, verfolgen Sie Änderungen und dokumentieren Sie neue Funktionen. Stellen Sie Support und Community-Ressourcen wie GitHub-Probleme und Foren bereit. Erstellen Sie praktische Beispiele, beispielsweise eine API-Dokumentation.

So wählen Sie das beste Golang-Framework für verschiedene Anwendungsszenarien aus So wählen Sie das beste Golang-Framework für verschiedene Anwendungsszenarien aus Jun 05, 2024 pm 04:05 PM

Wählen Sie das beste Go-Framework basierend auf Anwendungsszenarien aus: Berücksichtigen Sie Anwendungstyp, Sprachfunktionen, Leistungsanforderungen und Ökosystem. Gängige Go-Frameworks: Gin (Webanwendung), Echo (Webdienst), Fiber (hoher Durchsatz), gorm (ORM), fasthttp (Geschwindigkeit). Praktischer Fall: Erstellen einer REST-API (Fiber) und Interaktion mit der Datenbank (gorm). Wählen Sie ein Framework: Wählen Sie fasthttp für die Schlüsselleistung, Gin/Echo für flexible Webanwendungen und gorm für die Datenbankinteraktion.

Detaillierte praktische Erklärung der Golang-Framework-Entwicklung: Fragen und Antworten Detaillierte praktische Erklärung der Golang-Framework-Entwicklung: Fragen und Antworten Jun 06, 2024 am 10:57 AM

Bei der Go-Framework-Entwicklung treten häufige Herausforderungen und deren Lösungen auf: Fehlerbehandlung: Verwenden Sie das Fehlerpaket für die Verwaltung und Middleware zur zentralen Fehlerbehandlung. Authentifizierung und Autorisierung: Integrieren Sie Bibliotheken von Drittanbietern und erstellen Sie benutzerdefinierte Middleware zur Überprüfung von Anmeldeinformationen. Parallelitätsverarbeitung: Verwenden Sie Goroutinen, Mutexe und Kanäle, um den Ressourcenzugriff zu steuern. Unit-Tests: Verwenden Sie Gotest-Pakete, Mocks und Stubs zur Isolierung sowie Code-Coverage-Tools, um die Angemessenheit sicherzustellen. Bereitstellung und Überwachung: Verwenden Sie Docker-Container, um Bereitstellungen zu verpacken, Datensicherungen einzurichten und Leistung und Fehler mit Protokollierungs- und Überwachungstools zu verfolgen.

Was sind die häufigsten Missverständnisse im Lernprozess des Golang-Frameworks? Was sind die häufigsten Missverständnisse im Lernprozess des Golang-Frameworks? Jun 05, 2024 pm 09:59 PM

Beim Go-Framework-Lernen gibt es fünf Missverständnisse: übermäßiges Vertrauen in das Framework und eingeschränkte Flexibilität. Wenn Sie die Framework-Konventionen nicht befolgen, wird es schwierig, den Code zu warten. Die Verwendung veralteter Bibliotheken kann zu Sicherheits- und Kompatibilitätsproblemen führen. Die übermäßige Verwendung von Paketen verschleiert die Codestruktur. Das Ignorieren der Fehlerbehandlung führt zu unerwartetem Verhalten und Abstürzen.

See all articles