(PHP 8)
ReflectionClass::getAttributes — Recupera los atributos de una clase
Devuelve todos los atributos declarados en esta clase en forma de un array de objetos ReflectionAttribute.
name
Filter the results to include only ReflectionAttribute instances for attributes matching this class name.
flags
Flags for determining how to filter the results, if name
is provided.
Default is 0
which will only return results for attributes that
are of the class name
.
The only other option available, is to use ReflectionAttribute::IS_INSTANCEOF
,
which will instead use instanceof
for filtering.
Un array de atributos, en forma de objetos de tipo ReflectionAttribute.
Ejemplo #1 Uso básico de ReflectionClass::getAttributes()
<?php
#[Attribute]
class Fruit {
}
#[Attribute]
class Rouge {
}
#[Fruit]
#[Rouge]
class Pomme {
}
$class = new ReflectionClass('Pomme');
$attributes = $class->getAttributes();
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
El resultado del ejemplo sería:
Array ( [0] => Fruit [1] => Rouge )
Ejemplo #2 Filtrar los resultados por un nombre de clase
<?php
#[Attribute]
class Fruit {
}
#[Attribute]
class Rouge {
}
#[Fruit]
#[Rouge]
class Pomme {
}
$class = new ReflectionClass('Pomme');
$attributes = $class->getAttributes('Fruit');
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
El resultado del ejemplo sería:
Array ( [0] => Fruit )
Ejemplo #3 Filtrar los resultados por nombre de clase, con herencia
<?php
interface Couleur {
}
#[Attribute]
class Fruit {
}
#[Attribute]
class Rouge implements Couleur {
}
#[Fruit]
#[Rouge]
class Pomme {
}
$class = new ReflectionClass('Pomme');
$attributes = $class->getAttributes(Couleur::class, ReflectionAttribute::IS_INSTANCEOF);
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
El resultado del ejemplo sería:
Array ( [0] => Rouge )