Heim >Backend-Entwicklung >PHP-Tutorial >Anpassen von Datenumwandlungen mit Laravel -Abgüssen

Anpassen von Datenumwandlungen mit Laravel -Abgüssen

百草
百草Original
2025-03-06 02:31:09811Durchsuche

Customizing Data Transformations with Laravel Casts

Die kundenspezifische Casts-Funktion von

Laravel ermöglicht eine kundenspezifische Datenkonvertierung, über die integrierten Casting-Funktionen hinaus, um komplexe Datentypen und Geschäftslogik zu verarbeiten.

Folgendes ist ein Beispiel für die Formatung von Telefonnummern mit benutzerdefinierten Abzügen:

<?php namespace App\Casts;

use Illuminate\Contracts\Database\Eloquent\CastsAttributes;
use Illuminate\Database\Eloquent\Model;

class PhoneNumber implements CastsAttributes
{
    public function get(Model $model, string $key, mixed $value, array $attributes): string
    {
        return sprintf(
            "+%d (%d) %d-%d",
            ...explode('|', $value)
        );
    }

    public function set(Model $model, string $key, mixed $value, array $attributes): string
    {
        $value = preg_replace('/[^0-9]/', '', $value);
        return implode('|', [
            substr($value, 0, 1),
            substr($value, 1, 3),
            substr($value, 4, 3),
            substr($value, 7)
        ]);
    }
}

Ein weiteres Beispiel für die Adressformatierung:

<?php namespace App\Casts;

use Illuminate\Contracts\Database\Eloquent\CastsAttributes;
use Illuminate\Database\Eloquent\Model;

class Address implements CastsAttributes
{
    public function get(Model $model, string $key, mixed $value, array $attributes): array
    {
        $data = json_decode($value, true);

        return [
            'street' => $data['street'],
            'city' => $data['city'],
            'state' => $data['state'],
            'postal_code' => $data['postal_code'],
            'formatted' => sprintf(
                '%s, %s, %s %s',
                $data['street'],
                $data['city'],
                $data['state'],
                $data['postal_code']
            )
        ];
    }

    public function set(Model $model, string $key, mixed $value, array $attributes): string
    {
        return json_encode([
            'street' => $value['street'],
            'city' => $value['city'],
            'state' => $value['state'],
            'postal_code' => $value['postal_code']
        ]);
    }
}

In Ihrem Modell können Sie sie dann so verwenden:

class User extends Model
{
    protected $casts = [
        'address' => Address::class,
        'phone' => PhoneNumber::class
    ];
}

benutzerdefinierte Abgüsse bieten eine einfache, wiederverwendbare Möglichkeit, komplexe Datenumwandlungen zu bewältigen und gleichzeitig das Modell einfach und leicht zu warten.

Das obige ist der detaillierte Inhalt vonAnpassen von Datenumwandlungen mit Laravel -Abgüssen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn