首页 > php框架 > Laravel > 正文

Laravel如何使用访问器(Accessors)和修改器(Mutators)

穿越時空
发布: 2025-11-14 12:43:57
原创
359人浏览过
访问器用于格式化读取的数据,如首字母大写或组合字段;修改器用于处理写入的数据,如转小写或加密。1. 定义get{AttributeName}Attribute方法实现访问器;2. 定义set{AttributeName}Attribute方法实现修改器;3. 仅在Eloquent模型操作中生效,可结合$appends自动序列化。

laravel如何使用访问器(accessors)和修改器(mutators)

在 Laravel 中,访问器(Accessors)和修改器(Mutators)是 Eloquent 模型中非常实用的功能,用于在获取或设置模型属性时对数据进行格式化或处理。它们能让你更灵活地控制数据的读取与写入方式,而无需在业务逻辑中重复处理。

什么是访问器(Accessors)

访问器用于在从数据库获取属性值后,对其进行格式化处理。例如,将数据库中的小写姓名转换为首字母大写,或将时间戳转换为可读日期。

定义访问器的方法是:在模型中创建一个以 get{AttributeName}Attribute 命名的方法,其中 {AttributeName} 是你想要处理的字段名,采用驼峰命名法。

例如,假设数据库中有一个 first_name 字段,你想在获取时自动首字母大写:

public function getFirstNameAttribute($value) {     return ucfirst($value); }

这样,每次访问 $user->first_name 时,返回的值都会被自动格式化。

也可以组合多个字段,比如生成一个全名:

public function getFullNameAttribute() {     return $this->first_name . ' ' . $this->last_name; }

调用 $user->full_name 即可得到完整姓名。

什么是修改器(Mutators)

修改器用于在将数据保存到数据库之前对其进行处理。比如将邮箱统一转为小写、加密敏感信息或格式化日期。

定义修改器的方法是:创建一个以 set{AttributeName}Attribute 命名的方法。

图改改
图改改

在线修改图片文字

图改改 455
查看详情 图改改

例如,确保所有邮箱都以小写存储:

public function setEmailAttribute($value) {     $this->attributes['email'] = strtolower($value); }

这样无论传入的是大写还是混合大小写邮箱,保存时都会被规范化。

另一个常见用途是处理日期或序列化数组:

public function setProfileDataAttribute($value) {     $this->attributes['profile_data'] = json_encode($value); }

这允许你传入数组或对象,并自动将其转为 JSON 存储。

使用场景示例

  • 自动格式化电话号码、地址等用户输入
  • 敏感字段加密(如身份证、手机号)
  • 日期字段转换为 Carbon 实例便于操作
  • 图片路径拼接完整 URL
  • 状态字段映射为中文描述(如 1 => "启用")

注意:访问器和修改器只在通过模型操作数据时生效。如果使用 DB 类直接查询或更新,这些方法不会被调用。

小贴士

如果字段名包含多个单词,比如 created_at,对应的访问器应为 getCreatedAtAttribute。数据库字段使用蛇形命名,方法使用驼峰命名。

还可以将访问器字段加入模型的 $appends 属性中,使其在序列化时自动包含:

protected $appends = ['full_name'];

基本上就这些。合理使用访问器和修改器能让模型更干净,逻辑更集中,避免在控制器或视图中做重复的数据处理。不复杂但容易忽略。

以上就是Laravel如何使用访问器(Accessors)和修改器(Mutators)的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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