Smarty 框架的模板繼承是通過使用布局(layout)和塊(block)的概念來實現的。這種方法可以讓你創建一個基本的骨架模板,其中包含所有頁面共享的元素,如頁眉、頁腳和其他公共部分。然后,你可以在子模板中覆蓋和插入內容到這些塊中,從而實現樣式的靈活性和代碼的重用。
以下是使用 Smarty 模板繼承的基本步驟:
<!DOCTYPE html>
<html>
<head>
<title>{block name="title" /}</title>
</head>
<body>
<header>{block name="header" /}</header>
<main>{block name="content" /}</main>
<footer>{block name="footer" /}</footer>
</body>
</html>
在這個例子中,我們定義了四個塊:title、header、content 和 footer。
{extends file="layout.tpl"}
{block name="title"}Child Page Title{/block}
{block name="header"}
<p>This is the child page header.</p>
{/block}
{block name="content"}
<p>This is the child page content.</p>
{/block}
{block name="footer"}
<p>This is the child page footer.</p>
{/block}
在這個例子中,我們使用 {extends}
標簽來指定要繼承的布局文件,并使用 {block}
標簽來覆蓋和插入內容到布局文件中的塊。
assign
函數來設置要傳遞給模板的數據,并使用 display
函數來顯示模板。例如:<?php
require_once 'Smarty.class.php';
$smarty = new Smarty();
$smarty->assign('title', 'Child Page');
$smarty->display('child.tpl');
?>
這將使用 child.tpl 模板,并傳遞一個名為 “title” 的變量。然后,child.tpl 將使用布局文件,并替換其中的塊。
通過這種方式,你可以創建一個可重用的布局模板,并在多個子模板中輕松維護和擴展。