Php/docs/arrayaccess.offsetexists

提供:Dev Guides
< Php
移動先:案内検索

ArrayAccess::offsetExists

(PHP 5, PHP 7, PHP 8)

ArrayAccess::offsetExistsオフセットが存在するかどうか


説明

abstract public ArrayAccess::offsetExists ( mixed $offset ) : bool

オフセットが存在するかどうかを返します。

このメソッドが実行されるのは、ArrayAccess を実装したオブジェクト上で isset() あるいは empty() を使用した場合です。

注意:

empty() を使用すると ArrayAccess::offsetGet() がコールされ、ArrayAccess::offsetExists()true を返すかどうかで空かどうかを判断します。

パラメータ

offset
調べたいオフセット。


返り値

成功した場合に true を、失敗した場合に false を返します。

注意:

非 boolean 値が返された場合は bool にキャストして返します。

例1 ArrayAccess::offsetExists() の例

<?phpclass obj implements arrayaccess {    public function offsetSet($offset, $value) {        var_dump(__METHOD__);    }    public function offsetExists($var) {        var_dump(__METHOD__);        if ($var == "foobar") {            return true;        }        return false;    }    public function offsetUnset($var) {        var_dump(__METHOD__);    }    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)