daily-email: add 2023-04-13
This commit is contained in:
parent
6f3caa3ef3
commit
e416da6aab
35
src/content/daily-email/2023-04-13.md
Normal file
35
src/content/daily-email/2023-04-13.md
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
---
|
||||||
|
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
|
Loading…
Reference in a new issue