首页
/ Laravel-Data 4.12.0 版本发布:更强大的数据对象处理能力

Laravel-Data 4.12.0 版本发布:更强大的数据对象处理能力

2025-07-01 23:01:13作者:沈韬淼Beryl

项目简介

Laravel-Data 是一个为 Laravel 框架设计的强大数据对象处理包,它提供了一种结构化的方式来定义和处理应用程序中的数据。通过将数据封装在专门的类中,开发者可以获得更好的类型安全、自动验证和转换功能。这个包特别适合在 API 开发、表单处理和复杂业务逻辑中使用。

4.12.0 版本亮点

最新发布的 4.12.0 版本带来了多项重要改进和新功能,显著提升了数据对象处理的灵活性和便利性。

1. 禁用 Optional 值的新选择

Optional 类型在 Laravel-Data 中非常有用,它允许某些字段在数据对象中是可选的。然而,在某些场景下,开发者可能更希望这些可选字段直接返回 null 而不是 Optional 对象。

新版本引入了 withoutOptionalValues() 方法,让开发者可以灵活控制这种行为:

class SongData extends Data {
    public function __construct(
        public string $title,
        public string $artist,
        public Optional|null|string $album,
    ) {
    }
}

// 使用新方法,album 将返回 null 而不是 Optional
SongData::factory()
    ->withoutOptionalValues()
    ->from(['title' => 'Never gonna give you up', 'artist' => 'Rick Astley']);

2. 增强的属性值注入功能

Laravel-Data 现在支持更丰富的属性值注入方式。除了原有的路由参数注入外,新增了从服务容器和认证用户中注入值的能力。

class SongData extends Data {
    #[FromAuthenticatedUser]
    public UserData $user;  // 自动注入当前认证用户
}

这个功能极大简化了常见场景下的数据对象创建过程,特别是在需要当前用户信息的业务逻辑中。

3. 验证规则合并机制

在之前的版本中,手动定义验证规则会完全覆盖自动生成的规则。4.12.0 版本引入了 MergeValidationRules 特性,允许开发者将自定义规则与自动生成的规则合并:

#[MergeValidationRules]
class SongData extends Data
{
    public function __construct(
        public string $title,
        public string $artist,
    ) {
    }

    public static function rules(): array
    {
        return [
            'title' => ['max:20'],  // 将与自动生成的规则合并
            'artist' => ['max:20'],
        ];
    }
}

这种方式既保留了自动验证的便利性,又提供了足够的灵活性来添加特定业务规则。

4. 新增属性映射器

新版本内置了两个实用的属性名称映射器:

  • Uppercase:将属性名转换为全大写
  • Lowercase:将属性名转换为全小写

这些映射器在处理不同命名约定的API或数据库时特别有用。

其他重要改进

  1. 枚举序列化支持:现在可以正确处理枚举类型的JSON序列化。
  2. DateTime精度处理:优化了DateTimeInterface类型的处理,确保纳秒精度与微秒精度的兼容性。
  3. 授权方法依赖注入Data::authorize() 方法现在支持依赖注入。
  4. 代码质量提升:多项内部重构和优化,提高了包的稳定性和性能。

升级建议

对于正在使用 Laravel-Data 的开发者,4.12.0 版本提供了向后兼容的改进,升级过程应该是平滑的。特别推荐关注以下场景的改进:

  • 需要更精细控制 Optional 行为的应用
  • 需要从认证用户或容器注入数据的场景
  • 需要合并自动和手动验证规则的项目
  • 处理不同命名约定的API集成

这个版本通过多项实用功能的添加,进一步巩固了 Laravel-Data 作为 Laravel 生态中数据对象处理首选方案的地位。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K