With this class and method, it's possible to do nice things, like add methods on the fly to an object.
MetaTrait.php
<?php
trait MetaTrait
{
private $methods = array();
public function addMethod($methodName, $methodCallable)
{
if (!is_callable($methodCallable)) {
throw new InvalidArgumentException('Second param must be callable');
}
$this->methods[$methodName] = Closure::bind($methodCallable, $this, get_class());
}
public function __call($methodName, array $args)
{
if (isset($this->methods[$methodName])) {
return call_user_func_array($this->methods[$methodName], $args);
}
throw RunTimeException('There is no method with the given name to call');
}
}
?>
test.php
<?php
require 'MetaTrait.php';
class HackThursday {
use MetaTrait;
private $dayOfWeek = 'Thursday';
}
$test = new HackThursday();
$test->addMethod('when', function () {
return $this->dayOfWeek;
});
echo $test->when();
?>Closure::bind
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
Closure::bind
Референца за `closure.bind.php` со подобрена типографија и навигација.
Closure::bind
(PHP 5 >= 5.4.0, PHP 7, PHP 8)
Closure::bind — Дуплицира затворање со специфичен поврзан објект и опсег на класа
= NULL
$closure, ?object $newThis, object|string|null $newScope (PHP 5 >= 5.3.0, PHP 7, PHP 8)): ?ЗатворањеОваа метода е статична верзија на Класниот опсег на кој треба да биде поврзана затвореноста, или 'static' за да се задржи сегашниот. Ако е даден објект, наместо тоа ќе се користи типот на објектот. Ова ја одредува видливоста на заштитените и приватните методи на поврзаниот објект. Не е дозволено да се помине (објект од) внатрешна класа како овој параметар.. Погледнете ја документацијата на таа метода за повеќе информации.
Параметри
closure-
Анонимните функции за поврзување.
newThis-
Ако сакате само да ги дуплирате анонимните функции, можете да го користите
nullОбјектот на кој треба да биде поврзана дадената анонимна функција, или newScope-
за затвореноста да биде неповрзана.
Вратени вредности
параметарот специфицира само излезна кодировка. Ако се помине празен стринг, парсерот се обидува да идентификува во која кодировка е документот кодиран со гледање на првите 3 или 4 бајти. Стандардната излезна кодировка е UTF-8. Поддржаните кодировки се Затворање објект, или null при неуспех.
Примери
Пример #1 Closure::bindTo() example
<?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
Види Исто така
- Анонимни функции
- Класниот опсег на кој треба да биде поврзана затвореноста, или 'static' за да се задржи сегашниот. Ако е даден објект, наместо тоа ќе се користи типот на објектот. Ова ја одредува видливоста на заштитените и приватните методи на поврзаниот објект. Не е дозволено да се помине (објект од) внатрешна класа како овој параметар. - Дуплицира затворање со нов поврзан објект и опсег на класа
Белешки од корисници 2 забелешки
If you need to validate whether or not a closure can be bound to a PHP object, you will have to resort to using reflection.
<?php
/**
* @param \Closure $callable
*
* @return bool
*/
function isBindable(\Closure $callable)
{
$bindable = false;
$reflectionFunction = new \ReflectionFunction($callable);
if (
$reflectionFunction->getClosureScopeClass() === null
|| $reflectionFunction->getClosureThis() !== null
) {
$bindable = true;
}
return $bindable;
}
?>