ReflectionClassConstant::getAttributes
(PHP 8)
ReflectionClassConstant::getAttributes — アトリビュートを取得する
説明
このクラス定数上で宣言されている全てのアトリビュートを ReflectionAttribute の配列として返します。
パラメータ
name
-
指定したクラス名にマッチするアトリビュートの、 ReflectionAttribute のみを含むようにフィルタします。
flags
-
name
が指定されていた場合に、 結果をどうフィルタするかを決めるフラグ。デフォルトは
0
です。 この場合、アトリビュートのクラス名がname
であるものだけを返します。他の利用可能なオプションは、
ReflectionAttribute::IS_INSTANCEOF
です。 この場合、フィルタリングにinstanceof
を使います。
戻り値
アトリビュートの配列を、 ReflectionAttribute オブジェクトの配列として返します。
例
例1 基本的な使い方
<?php
#[Attribute]
class Fruit {
}
#[Attribute]
class Red {
}
class Basket {
#[Fruit]
#[Red]
public const APPLE = 'apple';
}
$classConstant = new ReflectionClassConstant('Basket', 'APPLE');
$attributes = $classConstant->getAttributes();
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
上の例の出力は以下となります。
Array ( [0] => Fruit [1] => Red )
例2 クラス名で結果をフィルタする
<?php
#[Attribute]
class Fruit {
}
#[Attribute]
class Red {
}
class Basket {
#[Fruit]
#[Red]
public const APPLE = 'apple';
}
$classConstant = new ReflectionClassConstant('Basket', 'APPLE');
$attributes = $classConstant->getAttributes('Fruit');
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
上の例の出力は以下となります。
Array ( [0] => Fruit )
例3 クラス名、かつ継承も考慮して結果をフィルタする
<?php
interface Color {
}
#[Attribute]
class Fruit {
}
#[Attribute]
class Red implements Color {
}
class Basket {
#[Fruit]
#[Red]
public const APPLE = 'apple';
}
$classConstant = new ReflectionClassConstant('Basket', 'APPLE');
$attributes = $classConstant->getAttributes('Color', ReflectionAttribute::IS_INSTANCEOF);
print_r(array_map(fn($attribute) => $attribute->getName(), $attributes));
?>
上の例の出力は以下となります。
Array ( [0] => Red )
参考
- ReflectionClass::getAttributes() - アトリビュートを取得する
- ReflectionFunctionAbstract::getAttributes() - アトリビュートを取得する
- ReflectionParameter::getAttributes() - アトリビュートを取得する
- ReflectionProperty::getAttributes() - アトリビュートを取得する
+add a note
User Contributed Notes
There are no user contributed notes for this page.
↑ and ↓ to navigate •
Enter to select •
Esc to close
Press Enter without
selection to search using Google