Синтаксис атрибутов состоит из нескольких частей. Во-первых, декларация
атрибута начинается с символа #[
и заканчивается
символом ]
. Во-вторых, внутри перечисляют один или несколько разделённых запятой атрибутов.
Имена атрибутов могут быть неполными, полными и абсолютными, как описано в разделе
Использование пространства имён: основы.
Аргументы атрибутов необязательны, но если они есть, то их заключают в круглые скобки ()
.
Аргументы атрибутов могут быть либо конкретными значениями (литералами), либо константными выражениями. Аргументы
можно записывать как позиционным, так и именованным синтаксисом.
Когда Reflection API запрашивает экземпляр класса атрибута, имя атрибута трактуется как имя запрашиваемого класса, а аргументы атрибута передаются в конструктор этого класса. Поэтому для каждого атрибута необходимо создавать класс.
Пример #1 Синтаксис атрибутов
<?php
// a.php
namespace MyExample;
use Attribute;
#[Attribute]
class MyAttribute
{
const VALUE = 'value';
private $value;
public function __construct($value = null)
{
$this->value = $value;
}
}
// b.php
namespace Another;
use MyExample\MyAttribute;
#[MyAttribute]
#[\MyExample\MyAttribute]
#[MyAttribute(1234)]
#[MyAttribute(value: 1234)]
#[MyAttribute(MyAttribute::VALUE)]
#[MyAttribute(array("key" => "value"))]
#[MyAttribute(100 + 200)]
class Thing
{
}
#[MyAttribute(1234), MyAttribute(5678)]
class AnotherThing
{
}