array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'es', ), 'this' => array ( 0 => 'closure.call.php', 1 => 'Closure::call', ), 'up' => array ( 0 => 'class.closure.php', 1 => 'Closure', ), 'prev' => array ( 0 => 'closure.bindto.php', 1 => 'Closure::bindTo', ), 'next' => array ( 0 => 'closure.fromcallable.php', 1 => 'Closure::fromCallable', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'es', 'path' => 'language/predefined/closure/call.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 7, PHP 8)
Closure::call — Vincula y llama al cierre
Vincula temporalmente el cierre a newThis
, y lo
llama con cualquier parámetro dado.
newThis
El object a vincular al cierre mientras dure la llamada.
args
Cero o más parámetros, que serán dados como parámetros al cierre.
Devuelve el valor devuelto por el cierre.
Ejemplo #1 Ejemplo de Closure::call()
<?php
class Valor {
protected $valor;
public function __construct($valor) {
$this->valor = $valor;
}
public function getValor() {
return $this->valor;
}
}
$tres = new Valor(3);
$cuatro = new Valor(4);
$cierre = function ($delta) { var_dump($this->getValor() + $delta); };
$cierre->call($tres, 4);
$cierre->call($cuatro, 4);
?>
El resultado del ejemplo sería:
int(7) int(8)