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

如果您在使用 Laravel Eloquent 模型时需要对字段进行格式化输出或写入前处理,则可以利用访问器(Accessors)和修改器(Mutators)实现数据的自动转换。以下是具体的使用方法。
本文运行环境:MacBook Pro,macOS Sonoma
Accessors 用于在从数据库获取属性值后对其进行格式化处理,例如将字符串转为驼峰格式、日期格式化等。Laravel 会自动检测并调用对应字段的访问器。
1、在 Eloquent 模型中创建一个方法,方法名遵循 get{Attribute}Attribute 的命名规范,其中 {Attribute} 是对应字段的驼峰式写法。
2、例如,数据库中有 first_name 字段,希望获取时自动转为大写:
public function getFirstNameAttribute($value)
{
return ucfirst($value);
}
3、当访问模型的 $model->first_name 时,返回值将自动经过此处理。
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'。
2、定义访问器以返回特定格式的时间字符串:
public function getCreatedAtAttribute($value)
{
return \Carbon\Carbon::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使用方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号