Blaze 是什么?

简介: Laravel Blaze 是 Livewire 推出的 Blade 组件编译时优化工具,通过预渲染、记忆化与折叠技术,将组件渲染性能提升最高17倍,安装即用,安全回退,专治 UI 密集型页面卡顿。(239字)

你已经优化了查询,加了缓存层,该做的都做了——但页面加载时总觉得哪里不对劲。那种说不清道不明的轻微延迟?问题很可能不在数据库,而在你的 Blade 组件。

好消息是:Livewire 团队刚刚发布了 Laravel 社区期待已久的解决方案 —— Blaze。

Blaze 是什么?

Blaze 是一个 Laravel 包,目标明确:通过编译时优化让 Blade 组件渲染速度大幅提升。它不再在每次请求时都重新评估静态组件,而是在编译阶段就预渲染好 —— 等用户访问页面时,繁重的计算工作早已完成。

他们用数据证明了这一点:

渲染 25,000 个可折叠按钮组件:

  • 未使用 Blaze:████████████████████████████████████████ 750ms
  • 使用 Blaze:██ 45ms

17 倍更快。这不是笔误。

Blade 为什么会变慢?

每次你调用 <x-button><x-card> 或任何 Blade 组件,Laravel 都要走一遍流程:解析模板、评估属性、执行 PHP 逻辑、输出 HTML。做一两次没问题。但想象一下,一个仪表盘页面有几百行表格数据、一个带 80 个选项的多选下拉框、或者每个卡片上都散布着图标 —— 这些组件每次请求都要从头处理一遍。

这正是 Blaze 要消除的开销。

安装 —— 两分钟上手

开始只需要一条命令:

composer require livewire/blaze:^1.0

Blaze 的工作原理 —— 三级优化策略

Blaze 没有采用一刀切的方案,而是提供了三种不同的优化策略,你可以根据需要选择。

优化编译器(默认)

这是基础策略。Blaze 用一个更高效的编译器替换 Blade 默认的编译器,把你的模板编译成更精简的 PHP 函数。不需要额外配置 —— 装完就能受益。根据文档,仅这一项就能为符合条件的组件减少高达 97% 的渲染开销。

记忆化(可选)

适合那些用相同属性反复出现的组件 —— 比如图标、头像缩略图、状态徽章或标签碎片。Blaze 第一次渲染时缓存输出结果,之后每次用相同属性调用时都直接复用。不用重新渲染,不用重复计算。

编译时折叠(可选)

这是最强力的策略。不是在运行时渲染,Blaze 在 Blade 编译阶段就把组件预渲染成纯静态 HTML。等应用真正运行时,这些组件在某种意义上已经"不存在"了 —— 它们早已被解析完毕。零运行时成本。

@blaze 指令 —— 比你想象的简单

要在组件上启用优化,只需在模板文件顶部加上 @blaze

{
  {-- resources/views/components/button.blade.php --}}

@blaze
@props(['variant' => 'primary'])

<button type="button" class="btn btn-{
  { $variant }}">
    {
  { $slot }}
</button>

如果你想精细控制启用哪些策略:

{
  {-- 启用全部(等同于只写 @blaze) --}}
@blaze(fold: true, memo: true, aware: true)

{
  {-- 跳过折叠,但保留记忆化 --}}
@blaze(fold: false, memo: true, aware: false)

想一次性优化整个目录而不动单个文件?也可以:

Blaze::optimize()
    ->in(resource_path('views/components/app'))
    ->in(resource_path('views/components/admin'));

什么时候该用 @blaze?

这是真正关键的部分。不是所有组件都适合加 @blaze —— 用错了地方可能导致难以追踪的隐蔽 Bug。

Blaze 提供了一个简单的判断标准。问自己这几个问题:

  • 对每个用户渲染结果都一样吗?(不用 auth(),不用按用户区分的数据)
  • 每次请求渲染结果都一样吗?(不用 CSRF 令牌,不用 request()->is()
  • 任何时间点渲染结果都一样吗?(不用 now(),不用相对时间戳)
  • 只使用你显式传入的属性吗?(不用 session 数据,不查数据库)
  • 它渲染的所有子组件也满足上述条件吗?

全部符合 → 加 @blaze。有任何一条不符合 → 跳过。

一个简单的判断思路:如果你能把组件丢进设计系统或 Storybook 里、不需要任何应用上下文就能正确渲染,那它就是合适的候选。按钮、卡片、徽章、图标、布局网格 —— 这些是最佳场景。

以下情况绝对不要@blaze

{
  {-- ❌ CSRF 令牌每次请求都变 --}}
<form method="POST">
    @csrf
    <button type="submit">Submit</button>
</form>

{
  {-- ❌ 认证状态是用户特定的 --}}
@auth
    <p>Welcome back!</p>
@endauth

{
  {-- ❌ Session 数据是动态的 --}}
<div>Hello, {
  { session('username') }}</div>

{
  {-- ❌ 激活链接状态依赖请求 --}}
@props(['href'])

<a href="{
  { $href }}" @class(['active' => request()->is($href)])>
    {
  { $slot }}
</a>

聪明的逃生舱:@unblaze

你可能会遇到这种场景:一个表单输入组件几乎完全是静态的 —— 唯独需要显示验证错误信息。这些错误来自请求,意味着整个组件没法折叠,对吧?

这就是 @unblaze 的用武之地。你可以在静态组件里"打洞",让特定区块保持运行时评估,同时保留周围所有标记的优化:

{
  {-- ✅ 表单输入配合 @unblaze 处理错误信息 --}}

@blaze

@props(['name', 'label'])

<div>
    <label>{
  { $label }}</label>
    <input type="text" name="{
  { $name }}">
    @unblaze
        @if($errors->has($name))
            <span class="text-red-500">{
  { $errors->first($name) }}</span>
        @endif
    @endunblaze
</div>

底层实现上:<div><label><input> 在编译时被折叠成静态 HTML。@unblaze 区块保持动态。鱼与熊掌 —— 优化和功能兼得。

需要把组件属性传进 @unblaze 区块?用 scope 参数:

@blaze

@props(['userId', 'showStatus' => true])

<div>
    {
  {-- 这里是一大段静态标记 --}}
    @unblaze(scope: ['userId' => $userId, 'showStatus' => $showStatus])
        @if($scope['showStatus'])
            <div>User #{
  { $scope['userId'] }} - Last seen: {
  { session('last_seen') }}</div>
        @endif
    @endunblaze
</div>

你也可以在一个组件里放多个 @unblaze 区块 —— 每个都创建一个独立的动态区域,其余部分保持折叠。

内置分析器 —— 快速定位瓶颈

Blaze 的一个亮点是内置分析器。不用猜哪个组件拖慢了性能,你能直接拿到火焰图、逐组件耗时和策略分解 —— 开箱即用。

Laravel Blaze Debug

一行代码开启:

Blaze::debug();

这在给应用做优化前后审计时特别有用,或者当你想知道为什么某个特定组件没有被折叠时。

Flux 用户的福音

如果你已经在用 Flux(Livewire 团队出品的 UI 组件库),这基本就是白捡的优化。所有符合条件的 Flux 组件已经标注了 @blaze —— 所以你一装上 Blaze,一切就自动开始工作,无需额外配置。

实际的性能预期

那个 17 倍的基准测试是真实的,但要说明背景:那是用 25,000 个完全相同的可折叠组件一次性渲染测出来的。真实应用里,你不太可能遇到这种场景。

根据官方文档,更现实的预期是:

  • 普通页面(几百个组件):提升 10–30ms
  • 组件密集型页面(数据表格、大型下拉框、重复的卡片网格):提升 50–100ms 以上

听起来可能不夸张,但如果你当前渲染时间是 300ms,降到 240ms,那就是 20% 的提升 —— 乘以每天每个用户的每次请求,累积起来很可观。

小结

Blaze 不是万能药 —— 它也没想做成万能药。它是一个专注、设计精良的工具,解决了很多 Laravel 应用在成长过程中默默遇到的特定问题。

它值得尝试的地方在于:对你的要求极低。不用重写模板,不用大规模重构,不用配置负担。如果某个组件无法优化,Blaze 会优雅地回退到正常渲染并继续。它只管干活。

如果你在用 Laravel 构建有大量可复用 UI 组件的应用 —— 尤其是什么设计系统之类的东西 —— Blaze 今天就可以加入你的工具箱。

告别 Laravel 缓慢的 Blade!Livewire Blaze 来了,为你的 Laravel 性能提速

目录
相关文章
|
6月前
|
SQL 人工智能 分布式计算
【MaxCompute SQL AI 实操教程】0元体验使用大模型提效数据分析
【MaxCompute SQL AI 实操教程】0元体验使用大模型提效数据分析
828 4
|
4月前
|
人工智能 API 机器人
OpenClaw 用户部署和使用指南汇总
本文档为OpenClaw(原MoltBot)官方使用指南,涵盖一键部署(阿里云轻量服务器年仅68元)、钉钉/飞书/企微等多平台AI员工搭建、典型场景实践及高频问题FAQ。同步更新产品化修复进展,助力用户高效落地7×24小时主动执行AI助手。
29785 253
|
4月前
|
文件存储 数据安全/隐私保护
ToDoList任务管理工具安装步骤详解(附任务创建与优先级设置教程)
ToDoList是一款轻量强大的本地任务管理工具,支持待办清单、优先级标记、截止提醒、项目分类与文件存储(.tdl格式),兼容Win7/10/11,无需联网,数据安全不丢失。安装简单,一键运行即用。
|
2月前
|
人工智能 安全 API
淘宝 API 技术架构与实战指南:从实时数据流到 AIGC 融合的电商开发新范式
本文系统解析2025年淘宝API 5.0技术跃迁:以实时数据流、GraphQL按需取数、隐私合规为新三角,融合6G、边缘计算与AIGC,实现毫秒级响应与智能服务。涵盖八大模块、安全架构、开发实战及行业案例,助开发者进阶电商创新。(239字)
|
4月前
|
JavaScript 搜索推荐 前端开发
从提示工程转向 上下文工程,6种让LLM在生产环境中稳定输出的技术
本文系统阐述“上下文工程”(Context Engineering)——生产级AI系统的核心能力。它不依赖提示词优化,而是通过选择性检索、上下文压缩、层次化布局、动态查询重构、记忆注入与工具感知六大技术,精准控制模型在运行时“看到什么、何时看、如何看”,从而根治幻觉、提升准确率、降低Token消耗,让小模型也能稳定输出高质量结果。
651 16
从提示工程转向 上下文工程,6种让LLM在生产环境中稳定输出的技术
|
4月前
|
人工智能 算法 搜索推荐
算法备案必看:多产品≠多备案!被驳回的 “重复申请” 坑一次讲清
AI企业多产品算法备案常陷“重复申请”误区。本文揭秘:同主体、同算法仅场景不同,只需1份备案,关联多个产品即可;唯算法类型/原理不同时才需分开。附命名规范、填报要点与避坑指南,助您一次过审。(239字)
算法备案必看:多产品≠多备案!被驳回的 “重复申请” 坑一次讲清
|
3月前
|
缓存 数据可视化 Linux
用Mac的朋友们,你们都在使用Homebrew了吗
Homebrew是macOS/Linux主流包管理器,支持命令行工具(`brew install`)和GUI应用(`brew install --cask`)的一键安装、升级、搜索与卸载。提供官网及国内镜像安装方式,附带Applite等图形化管理工具,大幅提升Mac软件管理效率。(239字)
1035 1
|
4月前
|
人工智能 API 开发工具
AI Compose Commit:用 AI 智能重构 Git 提交工作流
HagiCode 推出「AI Compose Commit」功能,利用 AI 智能分析未提交变更,自动分组逻辑提交、生成符合 Conventional Commits 规范的提交信息,并一键执行。支持多仓库、异步处理与实时通知,大幅提升 Git 工作流效率,让开发者专注编码而非琐碎提交。(239字)
577 15
|
4月前
|
机器学习/深度学习 监控 并行计算
基于 YOLO26 的打架斗殴行为智能检测(中英文双版) | 附完整源码与效果演示
本项目基于最新的 YOLO26 目标检测算法,实现了对打架斗殴行为的智能检测系统。通过构建专门的数据集、优化模型配置、进行充分的训练和测试,系统在打架斗殴行为检测方面取得了良好的效果。

热门文章

最新文章