Déclaration des classes d'attributs

Il est recommandĂ© de dĂ©finir une classe distincte pour chaque attribut. Dans le cas le plus simple, une classe vide avec la dĂ©claration #[Attribute] est suffisante. L'attribut peut ĂȘtre importĂ© depuis le namespace global Ă  l'aide d'une instruction use.

Exemple #1 Classe d'attribut simple

<?php

namespace Example;

use
Attribute;

#[
Attribute]
class
MyAttribute
{
}

Pour restreindre les types de dĂ©clarations auxquels un attribut peut ĂȘtre appliquĂ©, il convient de passer un masque de bits en premier argument de la dĂ©claration #[Attribute].

Exemple #2 Utilisation de la spécification de la cible pour restreindre l'utilisation des attributs

<?php

namespace Example;

use
Attribute;

#[
Attribute(Attribute::TARGET_METHOD | Attribute::TARGET_FUNCTION)]
class
MyAttribute
{
}

La déclaration de MyAttribute sur un autre type lÚvera désormais une exception lors de l'appel à ReflectionAttribute::newInstance()

Les cibles suivantes peuvent ĂȘtre spĂ©cifiĂ©es:

Par dĂ©faut, un attribut ne peut ĂȘtre utilisĂ© qu'une seule fois par dĂ©claration. Pour autoriser un attribut Ă  ĂȘtre rĂ©pĂ©tĂ©, il faut le spĂ©cifier dans le masque de bits de la dĂ©claration #[Attribute] en utilisant le drapeau Attribute::IS_REPEATABLE.

Exemple #3 Utilisation de IS_REPEATABLE pour permettre Ă  un attribut d'ĂȘtre utilisĂ© plusieurs fois dans une dĂ©claration

<?php

namespace Example;

use
Attribute;

#[
Attribute(Attribute::TARGET_METHOD | Attribute::TARGET_FUNCTION | Attribute::IS_REPEATABLE)]
class
MyAttribute
{
}
add a note

User Contributed Notes 1 note

up
16
esdras-schonevald ¶
4 years ago
#! Require PHP >= 8.0

#! This is a Sample

<?php

declare(strict_types = 1);

#[Attribute]
class Foo
{
    function __construct(){
        echo "Running " . __METHOD__ . PHP_EOL;
    }
}

#[Attribute(Attribute::TARGET_CLASS|Attribute::IS_REPEATABLE)]
class Bar {
    function __construct(?string ...$args){
        echo "Running " . __METHOD__ ,
            " args: " . implode(", ", $args) . PHP_EOL;
    }
}

#[Attribute(Attribute::TARGET_ALL)]
class Baz {
    function __construct(
        private string $parameter
    ){
        echo "Running " . __METHOD__ ,
            " arg: " . $this->parameter . PHP_EOL;
    }
}

#[Foo]                                      // [0]
#[Bar]                                      // [1]
#[Bar("Banana")]                            // [2]
#[Bar("Banana", "Apple", "Lemon", "Grape")] // [3]
#[Baz("The Only One")]                      // [4]
class Qux
{
}

// Getting class attribute with ReflectionClass
$ref    =   new ReflectionClass(Qux::class);
$attrs  =   $ref->getAttributes(); // Array of attributes

$attrs[0]->newInstance(); // "Running Foo::__construct"
$attrs[1]->newInstance(); // "Running Bar::__construct args: "
$attrs[2]->newInstance(); // "Running Bar::__construct args: Banana"
$attrs[3]->newInstance(); // "Running Bar::__construct args: Banana, Apple, Lemon, Grape"
$attrs[4]->newInstance(); // "Running Baz::__construct arg: The Only One"