(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
is_callable — Determina si un valor puede ser llamado como una función en el ámbito actual
Verifica que value
es un callable,
o que puede ser llamado utilizando la función
call_user_func().
value
El valor a verificar.
syntax_only
Si el argumento syntax_only
vale true
, la
función solo verificará si value
puede ser
una función o un método. Rechazará todos los valores
que no sean objetos invocables,
Closure, chaîne de caractèress, o tableaus que no tengan
una estructura válida para ser utilizados como un callback. Un array invocable válido
contiene 2 entradas: la primera debe ser un objeto
o un string, y la segunda un string.
callable_name
Recibe el "nombre de la función invocable", por ejemplo
"SomeClass::someMethod"
. Tenga en cuenta, sin embargo, que,
a pesar de la implicación de que SomeClass::someMethod()
es un método estático invocable, no es el caso.
Retorna true
si value
puede ser llamado como
una función, false
en caso contrario.
Ejemplo #1 Verificación si un string puede ser llamado como una función
<?php
function someFunction() {}
$functionVariable = 'someFunction';
var_dump(is_callable($functionVariable, false, $callable_name));
var_dump($callable_name);
?>
El resultado del ejemplo sería:
bool(true) string(12) "someFunction"
Ejemplo #2 Verificación si un array puede ser llamado como una función
<?php
class someClass
{
public function someMethod() {}
}
$anObject = new SomeClass();
$methodVariable = [$anObject, 'someMethod'];
var_dump(is_callable($methodVariable, true, $callable_name));
var_dump($callable_name);
?>
El resultado del ejemplo sería:
bool(true) string(21) "SomeClass::someMethod"
Ejemplo #3 is_callable() y los constructores
A pesar de que los constructores son los métodos que se llaman cuando un objeto es creado,
no son métodos estáticos y
is_callable() retornará false
para ellos. No es
posible utilizar is_callable() para verificar si una clase puede
ser instanciada desde el ámbito actual.
<?php
class Foo
{
public function __construct() {}
public function foo() {}
}
var_dump(
is_callable(['Foo', '__construct']),
is_callable(['Foo', 'foo'])
);
$foo = new Foo();
var_dump(is_callable([$foo, '__construct']));
?>
El resultado del ejemplo sería:
bool(false) bool(false) bool(true)
true
para cualquier método en ese objeto, incluso si
el método no está definido.