(PHP 5 >= 5.4.0, PHP 7)
Closure::bind — Duplica uma closure com um objeto vinculado e um escopo de classe
$closure
, object $newthis
[, mixed $newscope
= "static"
] )Este método é uma versão estática do Closure::bindTo(). Veja a documentação do método para mais informações.
closure
A função anônima a ser vincular.
newthis
O objeto que a função anônima fornecida deve vincular, ou
NULL
para a closure não vincular.
newscope
O escopo da classe a ser associada a closure deve ser informado, ou 'static' para manter o atual. Se um objeto é fornecido, o tipo do objeto será usado. Isso determina a visibilidade dos métodos protegidos e privados do objeto vinculado. Não é permitido passar uma (objeto da) classe interna como parâmetro this.
Retorna um novo objeto Closure ou FALSE
em caso de falha
Versão | Descrição |
---|---|
7.0.0 |
O parâmetro newscope não pode mais ser uma (objeto da)
classe interna, o que era possível em versões anteriores a esta.
|
Exemplo #1 Exemplo do método 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";
?>
O exemplo acima irá imprimir algo similar à:
1 2