Mutators is a method to modify data before setting model attributes, with the naming format set{AttributeName}Attribute; Accessors is a method to modify the return data when obtaining attributes, with the naming format get{AttributeName}Attribute. For example, setNameAttribute can convert the user name to lowercase and then store it; getCreatedAtAttribute can format date output. Common uses include cleaning input, encrypting sensitive fields, formatting time amount and other display content. When using it, you should pay attention to the case sensitivity of field names to avoid recursive calls causing dead loops. You should operate the $this->attributes array instead of directly accessing attributes. You can also create field alias through read-only Accessor and combine $casts to achieve more powerful type conversion functions. Mastering them reduces duplicate code and makes the model layer cleaner and more efficient.
In Laravel's Eloquent model, Mutators and Accessors are very practical tools. They allow you to format or process the data when fetching or setting model properties without having to write a lot of extra duplicate code.

What are Mutators and Accessors?
Simply put:

- Mutators are methods that run automatically before you set the model attribute value and are used to modify incoming data.
- Accessors is a method that automatically runs when you get the value of the model attribute, which is used to modify the returned data.
For example, you can use them to automatically convert the name entered by the user to lowercase when storing the user, or format the output when reading the date field.
How to use Mutators
The naming rules of Mutator are: set{AttributeName}Attribute
, where {AttributeName}
is the field name in the model, with the initial letter capitalization.

For example, suppose you have a User
model with a field called name
, and you want to convert the name to lowercase before saving:
public function setNameAttribute($value) { $this->attributes['name'] = strtolower($value); }
This way, when you execute:
$user = new User(); $user->name = 'John Doe'; $user->save();
The final database is johndoe
.
Common uses:
- Clean input data (such as trim, strtolower)
- Automatically encrypt sensitive fields (such as passwords)
- Format the upload file path
How to use Accessors
The naming rule of Accessor is: get{AttributeName}Attribute
, also based on the field name.
For example, you have a created_at
field that wants to return a formatted string when fetched:
public function getCreatedAtAttribute($value) { return date('Ym-d', strtotime($value)); }
Now calling $user->created_at
will return a format similar to 2025-04-05
.
If you also use a library like Carbon, you can write it more elegantly:
use Illuminate\Support\Carbon; public function getCreatedAtAttribute($value) { return Carbon::parse($value)->format('F j, Y'); }
This returns something like April 5, 2025
.
Common uses:
- Format time, amount, status and other display content
- Spliced field combination (such as full name)
- Convert boolean to human-readable formats like "yes/no"
Tips and precautions for use
Field names are case sensitive
- If your database field is underlined (such as
first_name
), then the method name should be written asgetFirstNameAttribute
orsetFirstNameAttribute
.
- If your database field is underlined (such as
Avoid a dead cycle
- Do not call
$this->字段名
directly in Mutator or Accessor, otherwise it may cause recursive calls to cause an error.$this->attributes['字段名']
should be operated.
- Do not call
Use attribute alias
Sometimes you don't want to expose the original field name, you can create an alias by defining a read-only Accessor. For example:
public function getFormattedNameAttribute() { return ucfirst($this->name); }
Then you can use
$user->formatted_name
to get the formatted name.-
Combined with Casts is more powerful
- Laravel also supports the
$casts
attribute for type conversion, such as automatically converting JSON strings into arrays. It works with Mutators/Accessors.
- Laravel also supports the
Basically that's it. Once you have mastered Mutators and Accessors, you will find that they can help you reduce a lot of repetitive logic, making the model layer cleaner and more centralized processing of data transformations.
The above is the detailed content of Using Mutators and Accessors in Laravel Eloquent Models. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

InLaravel,policiesorganizeauthorizationlogicformodelactions.1.Policiesareclasseswithmethodslikeview,create,update,anddeletethatreturntrueorfalsebasedonuserpermissions.2.Toregisterapolicy,mapthemodeltoitspolicyinthe$policiesarrayofAuthServiceProvider.

Yes,youcaninstallLaravelonanyoperatingsystembyfollowingthesesteps:1.InstallPHPandrequiredextensionslikembstring,openssl,andxmlusingtoolslikeXAMPPonWindows,HomebrewonmacOS,oraptonLinux;2.InstallComposer,usinganinstalleronWindowsorterminalcommandsonmac

The main role of the controller in Laravel is to process HTTP requests and return responses to keep the code neat and maintainable. By concentrating the relevant request logic into a class, the controller makes the routing file simpler, such as putting user profile display, editing and deletion operations in different methods of UserController. The creation of a controller can be implemented through the Artisan command phpartisanmake:controllerUserController, while the resource controller is generated using the --resource option, covering methods for standard CRUD operations. Then you need to bind the controller in the route, such as Route::get('/user/{id

Laravel allows custom authentication views and logic by overriding the default stub and controller. 1. To customize the authentication view, use the command phpartisanvendor:publish-tag=laravel-auth to copy the default Blade template to the resources/views/auth directory and modify it, such as adding the "Terms of Service" check box. 2. To modify the authentication logic, you need to adjust the methods in RegisterController, LoginController and ResetPasswordController, such as updating the validator() method to verify the added field, or rewriting r

Laravelprovidesrobusttoolsforvalidatingformdata.1.Basicvalidationcanbedoneusingthevalidate()methodincontrollers,ensuringfieldsmeetcriterialikerequired,maxlength,oruniquevalues.2.Forcomplexscenarios,formrequestsencapsulatevalidationlogicintodedicatedc

Selectingonlyneededcolumnsimprovesperformancebyreducingresourceusage.1.Fetchingallcolumnsincreasesmemory,network,andprocessingoverhead.2.Unnecessarydataretrievalpreventseffectiveindexuse,raisesdiskI/O,andslowsqueryexecution.3.Tooptimize,identifyrequi

InLaravelBladetemplates,use{{{...}}}todisplayrawHTML.Bladeescapescontentwithin{{...}}usinghtmlspecialchars()topreventXSSattacks.However,triplebracesbypassescaping,renderingHTMLas-is.Thisshouldbeusedsparinglyandonlywithfullytrusteddata.Acceptablecases

TomockdependencieseffectivelyinLaravel,usedependencyinjectionforservices,shouldReceive()forfacades,andMockeryforcomplexcases.1.Forinjectedservices,use$this->instance()toreplacetherealclasswithamock.2.ForfacadeslikeMailorCache,useshouldReceive()tod
