(PHP 5, PHP 7, PHP 8)
ArrayAccess::offsetExists — Verifica se uma posição existe
Verifica se uma posição existe ou não.
Este método é executado ao utilizar-se a função isset() ou empty() em objetos que implementem ArrayAccess.
Nota:
Ao utilizar a função empty(), o método ArrayAccess::offsetGet() será chamado e checado por vazio somente se o método ArrayAccess::offsetExists() retornar
true
offset
Uma posição a ser checada.
Retorna true
em caso de sucesso ou false
em caso de falha.
Nota:
O valor de retorno será convertido para bool se um não booleano for retornado.
Exemplo #1 Exemplo do método ArrayAccess::offsetExists()
<?php
class obj implements ArrayAccess {
public function offsetSet($offset, $value): void {
var_dump(__METHOD__);
}
public function offsetExists($var): bool {
var_dump(__METHOD__);
if ($var == "foobar") {
return true;
}
return false;
}
public function offsetUnset($var): void {
var_dump(__METHOD__);
}
#[\ReturnTypeWillChange]
public function offsetGet($var) {
var_dump(__METHOD__);
return "value";
}
}
$obj = new obj;
echo "Executa obj::offsetExists()\n";
var_dump(isset($obj["foobar"]));
echo "\nExecuta obj::offsetExists() e obj::offsetGet()\n";
var_dump(empty($obj["foobar"]));
echo "\nExecuta obj::offsetExists(), *não executa* obj:offsetGet()\n";
var_dump(empty($obj["foobaz"]));
?>
O exemplo acima produzirá algo semelhante a:
Executa obj::offsetExists() string(17) "obj::offsetExists" bool(true) Executa obj::offsetExists() e obj::offsetGet() string(17) "obj::offsetExists" string(14) "obj::offsetGet" bool(false) Executa obj::offsetExists(), *não executa* obj:offsetGet() string(17) "obj::offsetExists" bool(true)