Laravel通过访问器和修改器实现字段自动转换,访问器按get{Attribute}Attribute命名规范格式化读取值,如转大写、日期处理;修改器按set{Attribute}Attribute规范预处理写入值,如邮箱转小写;可自定义日期格式或创建虚拟属性如全名拼接;需注意方法为public、命名驼峰转换、避免性能损耗与副作用。

如果您在使用 Laravel Eloquent 模型时需要对字段进行格式化输出或写入前处理,则可以利用访问器(Accessors)和修改器(Mutators)实现数据的自动转换。以下是具体的使用方法。
本文运行环境:MacBook Pro,macOS Sonoma
一、定义 Accessors(访问器)
Accessors 用于在从数据库获取属性值后对其进行格式化处理,例如将字符串转为驼峰格式、日期格式化等。Laravel 会自动检测并调用对应字段的访问器。
1、在 Eloquent 模型中创建一个方法,方法名遵循 get{Attribute}Attribute 的命名规范,其中 {Attribute} 是对应字段的驼峰式写法。
2、例如,数据库中有 first_name 字段,希望获取时自动转为大写:
public function getFirstNameAttribute($value)
{
return ucfirst($value);
}
3、当访问模型的 $model->first_name 时,返回值将自动经过此处理。
二、定义 Mutators(修改器)
Mutators 用于在保存数据到数据库之前对属性值进行预处理,比如加密、格式标准化等。它确保写入的数据符合预期格式。
1、在模型中定义方法,命名规则为 set{Attribute}Attribute,{Attribute} 同样是字段名的驼峰形式。
2、例如,希望在存储邮箱前自动转为小写:
public function setEmailAttribute($value)
{
$this->attributes[’email’] = strtolower($value);
}
3、每次设置 $model->email = ‘User@Example.com’ 时,实际存入数据库的将是全小写形式。
三、处理日期字段的自动格式化
Laravel 默认通过 $dates 属性自动处理日期类型字段,但也可通过访问器自定义显示格式。
1、确保模型中已将字段加入 protected $dates 数组,如:‘created_at’。
AppMall应用商店
AI应用商店,提供即时交付、按需付费的人工智能应用服务
56 查看详情
2、定义访问器以返回特定格式的时间字符串:
public function getCreatedAtAttribute($value)
{
return CarbonCarbon::parse($value)->format(‘Y-m-d H:i’);
}
3、此后访问 $model->created_at 将返回格式化后的字符串。
四、使用访问器组合派生属性
您可以创建不对应数据库字段的虚拟属性,通过访问器动态生成组合值。
1、定义一个访问器返回多个字段拼接的结果,例如全名:
public function getFullNameAttribute()
{
return $this->first_name . ‘ ‘ . $this->last_name;
}
2、在模型实例上调用 $model->full_name 即可获取拼接结果。
3、该属性不会被自动保存到数据库,仅用于读取时展示。
五、注意事项与最佳实践
在使用 Accessors 和 Mutators 时需注意命名规范和属性可见性,避免意外行为。
1、确保方法为 public,否则无法被 Eloquent 调用。
2、若字段名称含多个下划线,如 is_active_flag,则访问器应命名为 getIsActiveFlagAttribute。
3、避免在访问器中执行耗时操作或远程请求,以免影响性能。
4、修改器中不应修改其他非当前字段的属性值,防止产生副作用。
以上就是laravel Eloquent中accessors和mutators怎么用_laravel Eloquent accessors与mutators使用方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/267036.html
微信扫一扫
支付宝扫一扫