模板继承是一项更加灵活的模板布局方式,模板继承不同于模板布局,甚至来说,应该在模板布局的上层。模板继承其实并不难理解,就好比类的继承一样,模板也可以定义一个基础模板(或者是布局),并且其中定义相关的区块(block),然后继承(extend)该基础模板的子模板中就可以对基础模板中定义的区块进行重载。
因此,模板继承的优势其实是设计基础模板中的区块(block)和子模板中替换这些区块。
每个区块由{block} {/block}
标签组成。 下面就是基础模板中的一个典型的区块设计(用于设计网站标题):
{ block name="title"}<title>网站标题</title>{/block}
block标签必须指定name属性来标识当前区块的名称,这个标识在当前模板中应该是唯一的(也就是说不能有重复的name属性的值),block标签中可以包含任何模板内容,包括其他标签和变量。
{ block name="title"}<title>{ $web_title}</title>{/block}
你甚至还可以在区块中加载外部文件:
{ block name="include"}{ include file="Public:header" /}{/block}
一个模板中可以定义任意多个名称标识不重复的区块,如我们在view视图目录下定义一个base.html基础模板:
在子模板中,可以对基础模板中的区块进行重载定义,如果没有重新定义的话,则表示沿用基础模板中的区块定义,如果定义了一个空的区块,则表示删除基础模板中的该区块内容。
{___block__}这个标签,当区块中有这个标记时,就不只是直接重载这个区块,它表示引用所继承模板对应区块的内容到这个位置,最终这个区块是合并后的内容。
在当前子模板中,只能定义区块而不能定义其他的模板内容,否则将会直接忽略,并且只能定义基础模板中已经定义的区块。
模板可以多级继承,比如B继承了A,而C又继承了B,最终C中的区块会覆盖B和A中的同名区块,但C和B中的区块必须是A中已定义过的。
子模板中的区块定义顺序是随意的,模板继承的用法关键在于基础模板如何布局和设计规划了,如果结合原来的布局功能,则会更加灵活。
(子模版区域外面的信息不会被展现出来的)
包含文件
在当前模版文件中包含其他的模版文件使用include标签,标签用法:
{ include file='模版文件1,模版文件2,...' /}