0

0

Laravel Blade如何创建和继承布局_模板引擎布局与视图复用

冰火之心

冰火之心

发布时间:2025-10-23 08:55:01

|

221人浏览过

|

来源于php中文网

原创

Laravel Blade通过@extends、@section和@yield实现布局继承与内容填充,结合@push和@stack管理资源,提升代码复用性、结构一致性及维护效率,同时利用@include和@component实现高级组件化复用。

laravel blade如何创建和继承布局_模板引擎布局与视图复用

Laravel Blade通过@extends指令继承,并用@section@yield定义可填充区域来实现布局的创建和复用,极大地简化了前端视图的维护,确保了页面结构的一致性,同时也提升了开发效率。

解决方案

创建和继承Blade布局,核心在于定义一个基础的布局文件,然后让其他视图文件去扩展它。这就像盖房子先打好地基和框架,再往里面添砖加瓦。

首先,你需要一个主布局文件,通常放在resources/views/layouts目录下,比如app.blade.php。这个文件会包含所有页面共有的HTML结构,比如标签,以及导航栏、页脚等。





    
    
    @yield('title', '我的应用')
    
    
    @stack('styles') {{-- 用于子视图添加特定CSS --}}


    
@yield('content') {{-- 这是页面主体内容区域 --}}

© {{ date('Y') }} 我的公司. All rights reserved.

@stack('scripts') {{-- 用于子视图添加特定JS --}}

在这个主布局文件中,@yield('title', '我的应用')定义了一个名为title的占位符,如果子视图没有提供title,就默认显示“我的应用”。@yield('content')则是核心内容区域的占位符。@stack('styles')@stack('scripts')是更灵活的占位符,允许子视图“压入”多个内容块。

接着,创建一个子视图文件,比如resources/views/posts/index.blade.php,来继承这个布局。


@extends('layouts.app') {{-- 声明继承 layouts/app.blade.php 布局 --}}

@section('title', '文章列表') {{-- 填充 title 占位符 --}}

@section('content') {{-- 填充 content 占位符 --}}
    

所有文章

这里是文章列表的详细内容。

  • 文章一
  • 文章二
  • 文章三
@endsection @push('styles') {{-- 向 styles 栈压入特定CSS --}} @endpush @push('scripts') {{-- 向 scripts 栈压入特定JS --}} @endpush

这里,@extends('layouts.app')是关键,它告诉Blade这个视图要使用layouts/app.blade.php作为它的父布局。@section('title', '文章列表')@section('content')则分别填充了父布局中对应的@yield区域。而@push('styles')@push('scripts')则会将内容追加到父布局中对应的@stack区域。

这样一来,所有使用layouts.app布局的页面,都会拥有相同的导航和页脚,而每个页面只需要关注自己的独特内容,大大减少了重复代码。

Blade布局如何提升开发效率?理解其核心优势

我个人觉得,Blade布局在提升开发效率上简直是立竿见影。想当年,没有这样的机制时,改个导航栏或者页脚,得在几十个甚至上百个HTML文件里挨个找、挨个改,那种痛苦现在回想起来都觉得不可思议。有了布局,这一切都变得集中且可控。

它的核心优势在于:

  1. 代码复用(DRY原则):这是最直观的。公共的头部、尾部、侧边栏,只需要写一次。这不仅仅是减少了代码量,更重要的是降低了维护成本。想象一下,如果品牌Logo换了,或者导航菜单多了一个选项,你只需要修改app.blade.php这一个文件,所有页面都会同步更新。这比手动修改几十个文件要高效太多了。
  2. 结构一致性:一个网站的视觉和功能体验,很大程度上取决于其页面结构的一致性。Blade布局强制你将共用元素放在统一的地方,这保证了所有页面都有一个统一的外观和导航逻辑。用户在浏览网站时,体验会更流畅,不会因为页面结构突然变化而感到困惑。
  3. 关注点分离:布局文件负责整体框架,子视图只负责填充自己的内容。这让开发者可以更专注于当前任务,而不是被整个页面的HTML结构所干扰。前端工程师可以专注于布局的搭建和公共组件的开发,后端或内容开发者则可以专注于填充@yield('content')区域的具体业务逻辑和数据展示。这种分离让协作变得更简单,也减少了冲突。
  4. 易于维护和迭代:当项目需求变化时,比如要引入一个新的全局JS库,或者调整网站的整体响应式布局,你只需要修改布局文件。如果每个页面都有自己的完整HTML,那修改起来简直是灾难。布局的存在,让项目在长期维护和功能迭代时,变得更加灵活和可控。

可以说,Blade布局是现代Web开发中不可或缺的一部分,它把“少写代码,多做事情”的理念发挥得淋漓尽致。

在Blade模板中高效管理前端资源:CSS与JavaScript的最佳实践

管理CSS和JavaScript资源,在Blade布局中确实有一些技巧,用好了能让你的页面加载更快,代码更整洁。我通常会结合@yield@stack来处理。

对于CSS:

  • 全局CSS:那些所有页面都需要的基础样式,比如重置样式、UI框架(如Bootstrap或Tailwind CSS的基础部分),应该直接放在主布局文件(app.blade.php)的标签内。使用asset()辅助函数来引用:

  • 页面/模块特定CSS:有些样式只在特定页面或特定功能模块中使用,比如文章详情页的特殊排版,或者某个插件的样式。这时,我会使用@stack('styles')中创建一个占位符,然后在子视图中使用@push('styles')来添加:

    
    
        ...
        @stack('styles')
    
    
    
    @push('styles')
        
    @endpush

    这样做的好处是,避免了不必要的CSS加载,只在需要时才引入。

    MagickPen
    MagickPen

    在线AI英语写作助手,像魔术师一样在几秒钟内写出任何东西。

    下载

对于JavaScript:

  • 全局JS:像jQuery、Vue.js、React等框架,或者一些网站通用的工具函数库,通常放在标签的结束前。这样做可以确保HTML内容已经加载完毕,避免JS阻塞页面渲染。
    
    
        ...
        
        @stack('scripts') {{-- 在这里放置,确保页面内容已加载 --}}
    
  • 页面/模块特定JS:同CSS一样,对于只在特定页面运行的JS代码或库,使用@stack('scripts')@push('scripts')。我通常会把它们放在@stack('scripts')中,这样它们会在全局JS之后加载,确保依赖关系正确。
    
    @push('scripts')
        
        
    @endpush

最佳实践总结:

  1. 区分全局与局部:只把全局通用的资源放在主布局,特定页面的资源通过@push压入。
  2. CSS放头部,JS放尾部:这是Web性能优化的基本原则。CSS在头部能尽快渲染页面样式,JS在尾部能避免阻塞页面内容显示。
  3. 利用asset()辅助函数:它能正确生成资源文件的URL,尤其是在项目部署到子目录时非常有用。
  4. 版本控制/缓存清除:在webpack.mix.js或其他构建工具中,给资源文件添加哈希值(如app.css?id=abcdef),确保用户总能加载到最新版本。Laravel Mix就能很好地处理这些。

超越基础继承:Blade组件与局部视图的高级复用策略

除了基础的@extends@section,Blade还提供了更高级的复用机制,尤其是@include@component@slot,它们能帮助我们构建更模块化、更具维护性的前端代码。这不仅仅是代码复用,更是设计模式的体现。

1. @include:简单的局部视图复用

这是最简单的复用方式,用于引入一个不带太多逻辑、纯粹是HTML片段的视图文件。比如一个表单的某个输入框组、一个简单的警告信息或者一个社交分享按钮。


{{ $message ?? '这是一个提示信息。' }}
@include('partials.alert', ['type' => 'success', 'message' => '操作成功!']) @include('partials.alert') {{-- 不传参数时使用默认值 --}}

@include的优点是轻量级,但它会将父视图的所有变量都传递给被包含的视图,这有时会导致变量污染或意外行为。所以,我倾向于只用它来引入非常简单的、无状态的HTML片段。

2. @component@slot:更强大的组件化

@component是Blade中更强大的复用机制,它允许你创建带有明确接口(通过插槽@slot)和默认内容的“组件”。这更接近现代前端框架(如Vue、React)中组件的概念。它解决了@include变量污染的问题,并且提供了更清晰的结构。

假设我们想创建一个可复用的“卡片”组件:


{{ $header ?? '默认标题' }} {{-- 命名插槽的默认值 --}}
{{ $slot }} {{-- 匿名插槽,这是组件的主要内容 --}}
@isset($footer) {{-- 可选的命名插槽 --}} @endisset

然后在其他视图中使用这个组件:


@component('components.card')
    @slot('header')
        文章详情
    @endslot

    

这是文章的详细内容。

更多内容...

@slot('footer') 发布日期:2023-10-27 @endslot @endcomponent {{-- 也可以这样传递额外数据,作为变量在组件内部使用 --}} @component('components.card', ['header' => '另一个标题'])

这是另一个卡片的内容。

@endcomponent

这里,{{ $slot }}是默认的匿名插槽,用于接收组件标签内的所有内容。@slot('header')@slot('footer')则是命名插槽,允许你向组件的特定区域传递内容。这种方式让组件的接口非常清晰,且组件内部的变量是隔离的,不会影响外部。

何时选择哪种方式?

  • @include:适用于简单的、静态的HTML片段,或者那些只需要少量数据就能渲染的“局部视图”,比如一个通用的消息提示框,或者一个不带逻辑的导航链接列表。
  • @component:适用于更复杂的、带有特定结构和逻辑的UI元素,比如各种卡片、模态框、分页器、表单元素组。当你需要一个清晰的接口来传递内容和数据,并且希望组件内部逻辑与外部隔离时,@component是更好的选择。

掌握这些高级复用策略,能让你的Blade模板代码更加模块化,也更容易理解和维护。这不仅是代码层面的优化,更是架构思维上的提升。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

320

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

278

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

373

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

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

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

86

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

65

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

150

2023.09.12

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 24.9万人学习

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

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