解密ThinkPHP3.1.2版本之模板继承

作者:shichen2014 时间:2023-09-06 16:02:15 

模板继承是ThinkPHP3.1.2版本添加的一项更加灵活的模板布局方式,模板继承不同于模板布局,甚至来说,应该在模板布局的上层。模板继承其实并不难理解,就好比类的继承一样,模板也可以定义一个基础模板(或者是布局),并且其中定义相关的区块(block),然后继承(extend)该基础模板的子模板中就可以对基础模板中定义的区块进行重载。

因此,模板继承的优势其实是设计基础模板中的区块(block)和子模板中替换这些区块。
每个区块由<block></block>标签组成,并且不支持block标签的嵌套。
下面就是基础模板中的一个典型的区块设计(用于设计网站标题):


<block name="title"><title>网站标题</title></block>

block标签必须指定name属性来标识当前区块的名称,这个标识在当前模板中应该是唯一的,block标签中可以包含任何模板内容,包括其他标签和变量,例如:


<block name="title"><title>{$web_title}</title></block>

你甚至还可以在区块中加载外部文件:


<block name="include"><include file="Public:header" /></block>

一个模板中可以定义任意多个名称标识不重复的区块,例如下面定义了一个base.html基础模板:


<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<block name="title"><title>标题</title></block>
</head>
<body>
<block name="menu">菜单</block>
<block name="left">左边分栏</block>
<block name="main">主内容</block>
<block name="right">右边分栏</block>
<block name="footer">底部</block>
</body>
</html>

然后我们在子模板(其实是当前操作的入口模板)中使用继承:


<extend name="base" />
<block name="title"><title>{$title}</title></block>
<block name="menu">
<a href="/" >首页</a>
<a href="/info/" >资讯</a>
<a href="/bbs/" >论坛</a>
</block>
<block name="left"></block>
<block name="content">
<volist name="list" id="vo">
<a href="/new/{$vo.id}">{$vo.title}</a><br/>
{$vo.content}
</volist>
</block>
<block name="right">

最新资讯:


<volist name="news" id="new">
<a href="/new/{$new.id}">{$new.title}</a><br/>
</volist>
</block>
<block name="footer">
@ThinkPHP2012 版权所有
</block>

可以看到,子模板中使用了extend标签定义需要继承的模板,extend标签的用法和include标签一样,你也可以加载其他模板:


<extend name="Public:base" />

或者使用绝对文件路径加载


<extend name="./Tpl/Public/base.html" />

在当前子模板中,只能定义区块而不能定义其他的模板内容,否则将会直接忽略,并且只能定义基础模板中已经定义的区块。
例如,如果采用下面的定义:


<block name="title"><title>{$title}</title></block>
<a href="/" >首页</a>
<a href="/info/" >资讯</a>
<a href="/bbs/" >论坛</a>

导航部分将是无效的,不会显示在模板中。

在子模板中,可以对基础模板中的区块进行重载定义,如果没有重新定义的话,则表示沿用基础模板中的区块定义,如果定义了一个空的区块,则表示删除基础模板中的该区块内容。
上面的例子,我们就把left区块的内容删除了,其他的区块都进行了重载。
子模板中的区块定义顺序是随意的,模板继承的用法关键在于基础模板如何布局和设计规划了,如果结合原来的布局功能,则会更加灵活。

标签:ThinkPHP3.1.2
0
投稿

猜你喜欢

  • 用私有属性来拯救IE7缩放图片的失真

    2009-03-03 13:57:00
  • JavaScript实现淘宝网图片的局部放大功能

    2023-08-25 05:44:56
  • 基于JavaScript实现单选框下拉菜单添加文件效果

    2023-07-15 08:46:33
  • Python正则表达式匹配ip地址实例

    2023-06-13 15:06:12
  • Oracle 启动例程 STARTUP参数说明

    2009-07-07 10:26:00
  • 擦亮自己的眼睛去看SQL Server之历史渊源

    2011-08-29 15:40:53
  • Asp中如何设计跨越域的Cookie

    2008-10-24 09:46:00
  • shtml网页SSI使用详解

    2008-02-20 19:13:00
  • ASP动态页服务器端的处理原理

    2007-09-14 10:07:00
  • favicon.ico以及动态图片的实现

    2008-07-03 12:34:00
  • 详解python代码模块化

    2023-08-08 23:08:23
  • ASP自动解压RAR文件代码

    2007-11-06 13:29:00
  • javascript根据像素点取位置示例

    2023-09-03 22:58:54
  • js自动闭合html标签(自动补全html标记)

    2023-08-25 07:06:35
  • 两组字符串数据比较合并相同数据

    2008-07-31 17:27:00
  • 网页打开速度的心理学

    2009-03-26 13:18:00
  • 几个SQL SERVER应用问题解答

    2008-01-01 19:12:00
  • 用Javascript正则表达式验证Email地址

    2009-12-09 15:56:00
  • 关于长度单位pt、px、dpi的误解

    2008-06-01 13:30:00
  • Safari显示网页字体为超级无敌难看的宋体的原因

    2008-04-20 16:49:00
  • asp之家 网络编程 m.aspxhome.com