36 lines
1,000 B
Markdown
36 lines
1,000 B
Markdown
|
---
|
||
|
title: >
|
||
|
Immutable read-only properties in PHP 8.1
|
||
|
pubDate: 2023-04-13
|
||
|
permalink: >-
|
||
|
archive/2023/04/13/immutable-read-only-properties-in-php-8-1
|
||
|
tags:
|
||
|
- php
|
||
|
---
|
||
|
|
||
|
Continuing with yesterday's data transfer object (DTO) example, something that can be done since PHP 8.1 is to make properties read-only:
|
||
|
|
||
|
```php
|
||
|
class AccountDetails {
|
||
|
|
||
|
public function __construct(
|
||
|
public readonly string $accountNumber,
|
||
|
public readonly string $sortCode,
|
||
|
) {}
|
||
|
|
||
|
}
|
||
|
```
|
||
|
|
||
|
This means the public properties can be read and used without the need for getter methods, but cannot be overridden - making the DTO immutable.
|
||
|
|
||
|
Without `readonly`, a DTO can be created and the property values can be changed:
|
||
|
|
||
|
```php
|
||
|
$accountDetails = new AccountDetails('12345678', '00-00-00');
|
||
|
$accountDetails->accountNumber = 'banana';
|
||
|
```
|
||
|
|
||
|
With `readonly` set, you'd get a fatal error instead:
|
||
|
|
||
|
> Fatal error: Uncaught Error: Cannot modify readonly property AccountDetails::$accountNumber in /home/opdavies/tmp/example.php:13
|