ReflectionProperty::getAttributes

(PHP 8)

ReflectionProperty::getAttributesGets Attributes

Опис

public ReflectionProperty::getAttributes(?string $name = null, int $flags = 0): array

Returns all attributes declared on this class property as an array of ReflectionAttribute.

Параметри

name

Повернути примірники ReflectionAttribute для атрибутів з даною назвою класу.

flags

Прапорці, що визначають, як саме фільтрувати результати, якщо вказано параметр name.

0 (початкове значення) — повертаються результати для атрибутів, які мають назву класу name.

ReflectionAttribute::IS_INSTANCEOF — повертаються результати для атрибутів із застосуваннями instanceof.

Значення, що повертаються

Array of attributes, as a ReflectionAttribute object.

Приклади

Приклад #1 Basic usage

<?php
#[Attribute]
class
Fruit {
}

#[
Attribute]
class
Red {
}

class
Basket {
#[
Fruit]
#[
Red]
public
string $apple = 'apple';
}

$property = new ReflectionProperty('Basket', 'apple');
$attributes = $property->getAttributes();
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>

Поданий вище приклад виведе:

Array
(
    [0] => Fruit
    [1] => Red
)

Приклад #2 Filtering results by class name

<?php
#[Attribute]
class
Fruit {
}

#[
Attribute]
class
Red {
}

class
Basket {
#[
Fruit]
#[
Red]
public
string $apple = 'apple';
}

$property = new ReflectionProperty('Basket', 'apple');
$attributes = $property->getAttributes('Fruit');
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>

Поданий вище приклад виведе:

Array
(
    [0] => Fruit
)

Приклад #3 Filtering results by class name, with inheritance

<?php
interface Color {
}

#[
Attribute]
class
Fruit {
}

#[
Attribute]
class
Red implements Color {
}

class
Basket {
#[
Fruit]
#[
Red]
public
string $apple = 'apple';
}

$property = new ReflectionProperty('Basket', 'apple');
$attributes = $property->getAttributes('Color', ReflectionAttribute::IS_INSTANCEOF);
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>

Поданий вище приклад виведе:

Array
(
    [0] => Red
)

Прогляньте також

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top