<<<<<<< .mine =======
当前位置: 首页 > SEO > thinkphp模板继承

thinkphp模板继承

时间:2014-04-21 11:49:32
模板继承是3.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>

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

<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">

</block>

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



<extend name="Public:base" />



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



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



<a href="/" >首页</a>



<a href="/info/" >资讯</a>



<a href="/bbs/" >论坛</a>



这样导航栏是不会在模版里显示的

相关文章

Apache服务器ThinkPHP伪静态的设置方法

ThinkPHP 作为 PHP 框架,是单一入口的,那么其原始的 URL 便不是那么友好。但 ThinkPHP提供了各种...

论 产品经理的宝典

产品经理职位越来越火,有的公司建立以产品为中心的组织形式。网上有很多“产品经理的能力模型”,有人说这像是武林秘籍,修炼之...

国内CDN加速应该如何取舍?

最近的一年来,站长圈突然成了互联网各大巨头关注的焦点。一下子出来很多云服务,特别是免费CDN、抗攻击的更是引人瞩目。什么...

让页面元素“固定”位置(基于bootstrap)

如果你的页面布局为单页面导航,并希望导航条一直固定在顶部,让用户随时知道自己所处的位置,只需按照下面的步骤照着做就能实现...

优秀的网站简介

优秀的网站布局和设计,都是一些创意性的东西。这些算是不怕做不到,就怕想不到了。那么今天就来介绍一些比较好的网站。供大家参...
沪ICP备10034044号-12
400-685-0732
400-685-0732 在线咨询