每月免费发送 4,000 封电子邮件 | Mailtrap 现在发送真正的电子邮件!

Dagger 组件:Laravel Blade 组件的强大替代品

最后更新于 经过

Dagger Components:Laravel Blade Components 的强大替代方案(图片)

Laravel Blade 组件长期以来一直是可复用 UI 元素的首选解决方案。然而,默认的组件系统有时会显得不够完善,尤其是在处理深度嵌套结构或高渲染开销时。而 Dagger 组件则弥补了这一不足。

Dagger 是 John Koster 创建的一个 Laravel 扩展包,它为 Blade 组件提供了一种替代方案。John 创建此扩展包的目的是为了优化他参与过的包含大量组件的项目的性能并降低系统开销。此外,他还希望探索一些高级编译技术,以实现属性转发、槽转发和属性缓存等功能。

Dagger 编译器会在运行时之前处理组件模板,并将其直接集成到最终视图输出中,从而提升性能。因此,当渲染 Dagger 组件时,Laravel 的标准视图事件不会被触发。

要安装 Dagger,请使用 composer:

作曲家 要求 掉落物/匕首

接下来,运行 Artisan 命令来搭建所需的路径:

php 工匠 dagger:安装

这将在应用程序的资源目录中创建新目录:

资源/
匕首/
观看次数/

Dagger 允许你以与创建 Laravel 默认组件相同的方式创建组件,但它引入了一种新的函数式组件定义方法。在这种新方法中,组件定义的第一部分必须是一个 PHP 代码块,用于定义组件。

假设我们创建一个简单的 badge 成分。

@php
使用 功能 液滴\匕首\组件 ;
成分 () -> 道具 ([
'类型' => '信息' ,
'信息'
]) -> 验证属性 ([
'类型' => '必需的' ,
'信息' => '必需的' ,
]);
@endphp
< 跨度 班级 = 徽章徽章- {{ $类型 }} > {{ $消息 }} </ 跨度 >

如您所见,我们仍然可以定义属性并应用验证规则。

然后,我们可以在另一个 Blade 模板中使用以下方式引用此组件: <c-* 使用前缀代替默认值 <x-* Laravel 中的前缀。这有助于将它们与标准的 Blade 组件区分开来。

< C徽章 类型 = “成功” 信息 = “新的” />

如果您想使用其他前缀,可以对其进行配置。

主要特点

Dagger 的主要特性包括:

  • 访问父数据: 这样就可以使用 Blade 的函数从子组件内部访问父组件的数据。 @aware 指示。
  • 属性验证: 使用 Laravel 内置的验证规则来验证组件属性。
  • 编译器属性: 例如, #id 属性,可用于命名嵌套组件。
  • 缓存组件: 使用 Laravel 的缓存功能,因此您可以使用该功能缓存您的组件。 #cache 编译器属性。
  • 属性和属性转发: 一项强大的功能,允许您设置和覆盖嵌套组件的 props 和属性。
  • 时隙转发: 允许您设置深度嵌套组件的内容。
  • 输出修剪: 这将对组件的输出进行修剪,然后再将其渲染到客户端。
  • 模板: 允许组件的使用者覆盖组件的命名部分,类似于插槽,但这是在编译时而不是运行时完成的。
  • 混合料: 允许您将数据和通用行为注入到组件中。

了解更多关于此软件包的信息,包括高级使用示例 官方 Dagger 仓库 在 GitHub 上。

Yannick Lyn Fatt 的照片

Laravel News 的特约撰稿人和全栈 Web 开发人员。

归档于:
立方体

Laravel 时事通讯

加入超过 4 万名开发者的行列,不错过任何新的技巧、教程等内容。

图像
了解软科技

以每小时 20 美元的价格聘请具备人工智能专业知识的 Laravel 开发人员。48 小时内即可开始工作。

访问 Acquaint Softtech
Tinkerwell 徽标

廷克威尔

Laravel 开发者必备的代码运行器。可在本地和生产环境中体验 AI、自动补全和即时反馈功能。

廷克威尔
几天内即可获得 Laravel 代码审查徽标的专家指导

几天内即可获得 Laravel 代码审查方面的专家指导

专家级代码审查!两位拥有 10 年以上 Laravel 开发经验的开发者将为您提供清晰、实用的反馈,帮助团队构建更优质的应用程序。

几天内即可获得 Laravel 代码审查方面的专家指导
PhpStorm 标志

PhpStorm

首选的 PHP IDE,对 Laravel 及其生态系统提供广泛的开箱即用支持。

PhpStorm
Laravel Cloud 标志

Laravel 云

轻松创建和管理服务器,并在几秒钟内部署 Laravel 应用程序。

Laravel 云
了解 Softtech 的标志

了解软科技

Acquaint Softtech 提供 AI 就绪的 Laravel 开发人员,48 小时内即可上手,每月费用为 3000 美元,没有冗长的销售流程,并提供 100% 退款保证。

了解软科技
Kirschbaum 标志

樱桃树

提供创新和稳定性,确保您的Web应用程序取得成功。

樱桃树
Shift 标志

转移

还在运行旧版本的 Laravel?立即实现 Laravel 自动升级和代码现代化,让您的应用程序保持最新状态。

转移
鱼叉:新一代时间跟踪和发票标志

Harpoon:新一代时间跟踪和发票系统

新一代时间跟踪和计费软件,帮助您的机构规划和预测盈利的未来。

Harpoon:新一代时间跟踪和发票系统
Lucky Media 标志

幸运传媒

Get Lucky Now——拥有十余年经验的 Laravel 开发理想之选!

幸运传媒
SaaSykit:Laravel SaaS 入门套件徽标

SaaSykit:Laravel SaaS 入门套件

SaaSykit 是一个多租户 Laravel SaaS 入门套件,包含运行现代 SaaS 所需的所有功能,例如支付、美观的结账界面、管理面板、用户仪表盘、身份验证、现成组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 入门套件
Log User Activity in Your Laravel App with Activity Log v5  image

Log User Activity in Your Laravel App with Activity Log v5

阅读文章
使用新的 Cloud CLI 镜像从终端管理 Laravel Cloud

使用新的 Cloud CLI 从终端管理 Laravel Cloud

阅读文章
Laravel 13.3.0 图片中的单元测试属性及其他功能

Laravel 13.3.0 中的单元测试属性及更多功能

阅读文章
PAO:PHP 测试工具的代理优化输出图像

PAO:PHP 测试工具的代理优化输出

阅读文章
PhpStorm 2026.1 发布镜像

PhpStorm 2026.1 发布

阅读文章
使用 Laravel 构建 AI:智能工单分类及结构化输出图像

使用 Laravel 构建 AI:基于结构化输出的智能工单分诊

阅读文章