ArrayAccess::offsetExists
オフセットが存在するかどうか
説明
public bool ArrayAccess::offsetExists(mixed $offset
)
このメソッドが実行されるのは、ArrayAccess
を実装したオブジェクト上で isset あるいは
empty を使用した場合です。
注意:
empty を使用すると ArrayAccess::offsetGet
がコールされ、ArrayAccess::offsetExists が
true
を返すかどうかで空かどうかを判断します。
戻り値
成功した場合に true
を、失敗した場合に false
を返します。
注意:
非 boolean 値が返された場合は bool にキャストして返します。
例
例1 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 "Runs obj::offsetExists()\n";
var_dump(isset($obj["foobar"]));
echo "\nRuns obj::offsetExists() and obj::offsetGet()\n";
var_dump(empty($obj["foobar"]));
echo "\nRuns obj::offsetExists(), *not* obj:offsetGet() as there is nothing to get\n";
var_dump(empty($obj["foobaz"]));
?>
Runs obj::offsetExists()
string(17) "obj::offsetExists"
bool(true)
Runs obj::offsetExists() and obj::offsetGet()
string(17) "obj::offsetExists"
string(14) "obj::offsetGet"
bool(false)
Runs obj::offsetExists(), *not* obj:offsetGet() as there is nothing to get
string(17) "obj::offsetExists"
bool(true)