0

0

laravel Blade模板引擎如何传递数据和布局继承_Laravel Blade模板数据传递与布局继承教程

穿越時空

穿越時空

发布时间:2025-10-09 10:48:02

|

553人浏览过

|

来源于php中文网

原创

答案:Laravel Blade通过with()、数组或compact()传递数据,并支持布局继承。使用@extends定义主模板,@yield和@section填充内容,实现高效视图管理与结构复用,提升页面维护性。

laravel blade模板引擎如何传递数据和布局继承_laravel blade模板数据传递与布局继承教程

Laravel Blade 是 Laravel 自带的轻量级模板引擎,它允许你使用简洁的语法构建视图,并支持数据传递与布局继承。本文将直接讲解如何在 Blade 模板中传递数据以及实现布局继承,帮助你快速掌握核心用法。

Blade 中传递数据到模板

在控制器中渲染视图时,可以通过多种方式把数据传递给 Blade 模板。

1. 使用 with() 方法

控制器返回视图时调用 with() 添加变量:

return view('welcome')->with('name', 'Tom')->with('age', 25);

在 welcome.blade.php 中可以直接使用:
{{ $name }},今年 {{ $age }} 岁

2. 传递数组给 view()

更常见的方式是把数据以数组形式传入 view() 函数:

$data = [
    'title' => '个人主页',
    'user'  => ['name' => 'Jerry', 'email' => 'jerry@example.com']
];<br>
return view('profile', $data);

在 profile.blade.php 中可直接访问:

<h1>{{ $title }}</h1><br>{{ $user['name'] }}

3. 使用 compact() 简化代码

如果你已有变量,可以用 compact() 快速打包:

$name = 'Alice';<br>
$role = 'admin';<br>
return view('dashboard', compact('name', 'role'));

模板中即可使用 {{ $name }}{{ $role }}

Blade 布局继承:定义母版与填充内容

Blade 支持模板继承,通过定义一个主布局文件,其他页面可以继承并替换其中的内容区域。

1. 创建主布局文件(layouts/app.blade.php)

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载

在 resources/views/layouts/ 下创建 app.blade.php:

<!DOCTYPE html><br>
<html><br>
<head><br>
    <title>@yield('title', '默认标题')</title><br>
</head><br>
<body><br>
    <header><br>
        <h1>网站标题</h1><br>
        <nav><a href="/">首页</a></nav><br>
    </header><br><pre class='brush:php;toolbar:false;'><main><br>
    @yield('content')<br>
</main><br>

<footer><br>
    @section('footer')<br>
        <p>版权所有 © 2025</p><br>
    @show<br>
</footer><br>

</html>

说明:
- @yield('title') 定义可选标题区域,默认显示“默认标题”
- @yield('content') 是子页面必须填充的主要内容区
- @section ... @show 定义可被覆盖或追加的区块

2. 子页面继承布局(如 home.blade.php)

在子页面中使用 @extends 并填充内容:

@extends('layouts.app')<br><p>@section('title', '首页 - 我的网站')<br></p><p>@section('content')<br>
<h2>欢迎来到首页</h2><br>
<p>这是主页内容。</p><br>
@endsection

这样就会继承 app.blade.php 的结构,并替换 content 和 title 区域。

3. 可选区块与追加内容

如果希望保留父级内容并添加新内容,使用 @parent:

@section('footer')<br>
    @parent<br>
    <p>新增一行底部信息</p><br>
@endsection

常见使用技巧

实际开发中,合理组织模板结构能提升维护效率。

  • 主布局建议放在 resources/views/layouts/ 目录下
  • 公共组件如导航、侧边栏可用 @include 引入:@include('partials.nav')
  • 多个层级继承时,确保路径正确,例如:@extends('layouts.admin')
  • 避免在模板中写复杂逻辑,数据处理尽量放在控制器或服务类中

基本上就这些。掌握数据传递和布局继承后,你就能高效地构建结构清晰的 Laravel 页面。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

340

2024.04.09

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

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

293

2024.04.09

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

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

773

2024.04.09

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

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

385

2024.04.10

laravel入门教程
laravel入门教程

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

141

2025.08.05

laravel实战教程
laravel实战教程

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

85

2025.08.05

laravel面试题
laravel面试题

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

80

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

506

2026.03.04

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Python Web框架Flask进阶视频教程
Python Web框架Flask进阶视频教程

共12课时 | 3万人学习

Python Web框架Flask入门视频教程
Python Web框架Flask入门视频教程

共7课时 | 2.6万人学习

后盾网smaryt模板引擎视频教程
后盾网smaryt模板引擎视频教程

共14课时 | 2.7万人学习

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

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