(PHP 5 >= 5.4.0, PHP 7, PHP 8)
Closure::bind — Дублирует замыкание с конкретным связанным объектом и областью видимости класса
$closure
, ?object $newThis
, object|string|null $newScope
= "static"): ?ClosureЭтот метод — статическая версия метода Closure::bindTo(). Описание нестатической версии метода даёт дополнительную информацию.
closure
Анонимная функция, которую метод свяжет с объектом.
newThis
Объект, с которым метод свяжет анонимную функцию,
или null
, чтобы замыкание оставалось несвязанным.
newScope
При передаче строкового аргумента: название класса, с областью видимости которого метод свяжет замыкание, или ключевое слово 'static', чтобы замыкание сохранило текущую область видимости. При передаче объекта как аргумента: роль названия класса будет играть тип объекта. Параметр определяет видимость защищённых и закрытых методов связанного объекта. Нельзя передавать в параметр название или экземпляр объекта внутреннего PHP-класса.
Метод возвращает новый объект замыкания Closure
или null
, если возникла ошибка.
Пример #1 Пример использования метода Closure::bind()
<?php
class A
{
private static $sfoo = 1;
private $ifoo = 2;
}
$cl1 = static function() {
return A::$sfoo;
};
$cl2 = function() {
return $this->ifoo;
};
$bcl1 = Closure::bind($cl1, null, 'A');
$bcl2 = Closure::bind($cl2, new A(), 'A');
echo $bcl1(), "\n";
echo $bcl2(), "\n";
?>
Вывод приведённого примера будет похож на:
1 2