Closure::bind
(PHP 5 >= 5.4.0, PHP 7, PHP 8)
Closure::bind — Дублирует замыкание с указанием конкретного связанного объекта и области видимости класса
Описание
$closure
, object $newthis
, mixed $newscope
= "static"
) : Closure|falseЭтот метод является статическим вариантом Closure::bindTo(). Смотрите документацию к указанному методу для подробной информации.
Список параметров
-
closure
-
Анонимная функция для привязывания к объекту.
-
newthis
-
Объект, к которому будет привязана переданная анонимная функция, или
null
для отсоединения функции от ее текущего объекта. -
newscope
-
Область видимости класса, с которой должно быть связано замыкание или 'static' для сохранения текущей области видимости. Если передан объект, то будет использован его класс. Этот параметр определяет видимость protected (защищенных) и private (закрытых) методов привязанного объекта. Запрещено в качестве этого параметра передавать (объектом) внутренний класс.
Возвращаемые значения
Возвращает новый объект Closure или false
в случае возникновения ошибки
Примеры
Пример #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
Смотрите также
- Анонимные функции
- Closure::bindTo() - Дублирует замыкание с указанием связанного объекта и области видимости класса