0

0

ThinkPHP的模板继承怎么用?ThinkPHP如何复用布局文件?

煙雲

煙雲

发布时间:2025-08-02 20:05:01

|

560人浏览过

|

来源于php中文网

原创

模板继承通过创建基础模板并定义可覆盖的区块来减少重复代码,子模板使用{extend}继承并用{block}覆盖内容,多级继承需逐级使用{extend},为避免性能问题应减少继承层级、合理划分区块、启用模板缓存、使用cdn及避免模板内复杂逻辑,最终提升开发效率与页面性能。

ThinkPHP的模板继承怎么用?ThinkPHP如何复用布局文件?

模板继承,说白了,就是让你在ThinkPHP里少写重复代码,特别是那些页面公共的部分,比如头部、尾部、导航栏什么的。你可以定义一个基础模板,然后其他页面继承它,只修改需要变化的部分。这样,修改公共部分的时候,只需要改动基础模板,所有继承的页面就都更新了,省时省力。

ThinkPHP的模板继承怎么用?ThinkPHP如何复用布局文件?

解决方案

首先,你需要创建一个基础模板,通常命名为

base.html
或者
layout.html
之类的。这个基础模板里包含所有页面的公共部分,并且定义一些“区块”(block),用来给子模板填充内容。

立即学习PHP免费学习笔记(深入)”;

ThinkPHP的模板继承怎么用?ThinkPHP如何复用布局文件?
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>{block name="title"}默认标题{/block}</title>
    <link rel="stylesheet" href="/static/css/style.css">
</head>
<body>

    <div id="header">
        {block name="header"}
        <h1>网站头部</h1>
        {/block}
    </div>

    <div id="content">
        {block name="content"}
        <p>这里是默认内容,子模板可以覆盖。</p>
        {/block}
    </div>

    <div id="footer">
        {block name="footer"}
        <p>版权所有 © 2023</p>
        {/block}
    </div>

</body>
</html>

注意看上面的

{block}
标签,它定义了一个区块。
name
属性是区块的名字,子模板可以通过这个名字来覆盖或扩展这个区块的内容。

然后,创建一个子模板,比如

index.html
,继承基础模板。

ThinkPHP的模板继承怎么用?ThinkPHP如何复用布局文件?
{extend name="base" /}

{block name="title"}首页 - 我的网站{/block}

{block name="header"}
    {include file="public/nav" /}
{/block}

{block name="content"}
    <h2>欢迎来到我的网站!</h2>
    <p>这里是首页的内容。</p>
{/block}

这里,

{extend name="base" /}
表示继承
base.html
模板。然后在各个
{block}
里,就可以定义子模板的内容了。如果子模板没有定义某个区块,那么就会显示基础模板里该区块的默认内容。

{include file="public/nav" /}
是引入公共的导航栏文件。

关键点:

  • {extend name="base" /}
    :指定继承的模板。
  • {block name="区块名"}
    :定义区块,子模板可以覆盖或扩展。
  • {include file="模板文件路径" /}
    :引入其他模板文件,实现更细粒度的复用。

ThinkPHP模板继承的优势在于,它能显著减少重复代码,提高开发效率,并且让你的网站结构更清晰,更容易维护。

如何解决模板继承后样式丢失的问题?

这个问题通常是因为CSS或JS文件的路径不正确导致的。

  1. 路径问题: 确保你的CSS和JS文件的路径是相对于模板文件的正确路径。如果你把CSS文件放在

    public/static/css/
    目录下,并且你的模板文件在
    application/index/view/
    目录下,那么在模板文件中引用CSS文件时,应该使用相对于
    public
    目录的路径,例如:
    <link rel="stylesheet" href="/static/css/style.css">
    。 绝对路径
    /static/css/style.css
    从网站根目录开始寻找。 相对路径
    ./static/css/style.css
    从当前文件所在目录开始寻找。

  2. 继承后的路径: 如果你的CSS和JS文件是在基础模板中引用的,而子模板继承了基础模板,那么路径问题通常不会出现。但如果子模板需要引入额外的CSS或JS文件,那么同样需要注意路径的正确性。

  3. 浏览器缓存: 有时候,即使你的路径是正确的,浏览器也可能因为缓存而加载旧的CSS或JS文件。你可以尝试清除浏览器缓存,或者在CSS和JS文件的URL后面添加一个版本号,例如:

    <link rel="stylesheet" href="/static/css/style.css?v=1.0">

  4. 资源文件部署: 确保你的静态资源文件(CSS、JS、图片等)已经正确部署到服务器上,并且可以通过URL访问。

  5. 检查开发者工具 打开浏览器的开发者工具(通常是F12键),查看“Network”选项卡,检查是否有CSS或JS文件加载失败。如果有,可以查看具体的错误信息,帮助你找到问题所在。

  6. 使用公共函数: ThinkPHP提供了一些公共函数,可以帮助你生成正确的URL。例如,可以使用

    __PUBLIC__
    常量来表示
    public
    目录的URL。例如:
    <link rel="stylesheet" href="{:__PUBLIC__}/static/css/style.css">

    阳光订餐系统
    阳光订餐系统

    欢迎使用阳光订餐系统,本系统使用PHP5+MYSQL开发而成,距离上一个版本1.2.8发布已经有一年了。本系统集成了留言本,财务管理,菜单管理,员工管理,安全管理,WAP手机端等功能,并继续继承1.X老版本简单、实用、美观的特点,在老版本上的基础上做了如下更新:1.更简洁的前台与后台,菜单及功能布局更合理。2.更合理的文件结构,合理适度的模板机制以及OO运用,更易于理解的代码,更适于二次开发;3.

    下载

如何实现多级模板继承?

多级模板继承其实和单级继承的原理是一样的,只不过是继承的层级更多了。你可以创建一个基础模板,然后创建一个中间模板继承它,最后再创建一个子模板继承中间模板。

例如,你有三个模板:

base.html
(基础模板)、
layout.html
(中间模板)、
index.html
(子模板)。

base.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>{block name="title"}默认标题{/block}</title>
</head>
<body>

    <div id="header">
        {block name="header"}
        <h1>网站头部</h1>
        {/block}
    </div>

    <div id="content">
        {block name="content"}
        <p>这里是默认内容,子模板可以覆盖。</p>
        {/block}
    </div>

    <div id="footer">
        {block name="footer"}
        <p>版权所有 © 2023</p>
        {/block}
    </div>

</body>
</html>

layout.html

{extend name="base" /}

{block name="header"}
    {include file="public/nav" /}
{/block}

{block name="content"}
    <div class="container">
        {block name="main"}
        <p>这里是中间模板的内容,子模板可以覆盖。</p>
        {/block}
    </div>
{/block}

index.html

{extend name="layout" /}

{block name="title"}首页 - 我的网站{/block}

{block name="main"}
    <h2>欢迎来到我的网站!</h2>
    <p>这里是首页的内容。</p>
{/block}

在这个例子中,

index.html
继承了
layout.html
,而
layout.html
又继承了
base.html
。这样,
index.html
就可以同时使用
base.html
layout.html
中定义的区块和内容。

关键点:

  • 每一级模板都使用
    {extend name="模板名" /}
    来指定继承的模板。
  • 子模板可以覆盖或扩展父模板中定义的区块。
  • 多级继承可以让你更灵活地组织和复用模板代码。

如何避免模板继承带来的性能问题?

模板继承虽然方便,但如果使用不当,可能会带来性能问题。因为每次渲染一个页面,都需要加载和解析多个模板文件。

  1. 减少继承层级: 尽量减少模板继承的层级。层级越多,加载和解析的模板文件就越多,性能损耗也就越大。

  2. 合理划分区块: 合理划分区块,避免过度使用区块。如果一个区块的内容很少,或者很少被子模板覆盖,那么可以考虑直接把内容写在基础模板中,而不是定义一个区块。

  3. 使用缓存: ThinkPHP提供了模板缓存功能,可以把解析后的模板文件缓存起来,下次渲染同一个页面时,直接使用缓存,避免重复解析模板文件。

    // 在config/template.php中配置
    'cache_prefix' => 'tpl_',
    'cache_time'   => 3600, // 缓存时间,单位秒
  4. 使用静态缓存: 对于一些不经常变化的页面,可以使用静态缓存,把整个页面的HTML代码缓存起来,下次访问直接返回缓存的HTML代码,避免执行任何PHP代码。

  5. 优化数据库查询: 模板中经常会用到数据库查询的结果。优化数据库查询,减少查询次数,可以显著提高页面性能。

  6. 使用CDN: 把静态资源文件(CSS、JS、图片等)放在CDN上,可以加快资源的加载速度,提高页面性能。

  7. 避免在模板中执行复杂的逻辑: 模板的主要作用是展示数据,应该避免在模板中执行复杂的逻辑。如果需要在模板中执行复杂的逻辑,可以考虑把逻辑放在控制器中,然后把结果传递给模板。

总的来说,模板继承是ThinkPHP中一个非常实用的功能,可以帮助你更好地组织和复用模板代码。但是,在使用模板继承时,也需要注意一些性能问题,避免过度使用继承,合理划分区块,使用缓存等手段,可以有效地提高页面性能。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

thinkphp性能怎么样
thinkphp性能怎么样

thinkphp 是一款高性能的 php 框架,具备缓存机制、代码优化、并行处理和数据库优化等优势。官方性能测试显示,它每秒可处理超过 10,000 个请求,实际应用中被广泛用于京东商城、携程网等大型网站和企业系统。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

357

2024.04.10

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1564

2023.10.24

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6151

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号