PHPマニュアル/PEARマニュアル | ユーザフォーラムで議論/質問 | マニュアル検索 | ハイライト | ハイライトオフ | ポータル | php spot

JsonSerializable::jsonSerialize - JSON にシリアライズしたいデータを指定する | JavaScript入門&応用&リファレンスなら「JavaScriptist」

  

JsonSerializable::jsonSerialize

(PHP 5 >= 5.4.0, PHP 7)

JsonSerializable::jsonSerializeJSON にシリアライズしたいデータを指定する

説明

abstract public mixed JsonSerializable::jsonSerialize ( void )

オブジェクトをシリアライズして、 json_encode() がネイティブにシリアライズできる値にします。

パラメータ

この関数にはパラメータはありません。

返り値

json_encode() でシリアライズするデータを返します。 resource 型以外の任意の型になります。

例1 JsonSerializable::jsonSerialize() で配列を返す例

<?php
class ArrayValue implements JsonSerializable {
    public function 
__construct(array $array) {
        
$this->array $array;
    }

    public function 
jsonSerialize() {
        return 
$this->array;
    }
}

$array = [123];
echo 
json_encode(new ArrayValue($array), JSON_PRETTY_PRINT);
?>

上の例の出力は以下となります。

[
    1,
    2,
    3
]

例2 JsonSerializable::jsonSerialize() で連想配列を返す例

<?php
class ArrayValue implements JsonSerializable {
    public function 
__construct(array $array) {
        
$this->array $array;
    }

    public function 
jsonSerialize() {
        return 
$this->array;
    }
}

$array = ['foo' => 'bar''quux' => 'baz'];
echo 
json_encode(new ArrayValue($array), JSON_PRETTY_PRINT);
?>

上の例の出力は以下となります。

{
    "foo": "bar",
    "quux": "baz"
}

例3 JsonSerializable::jsonSerialize() で整数値を返す例

<?php
class IntegerValue implements JsonSerializable {
    public function 
__construct($number) {
        
$this->number = (integer) $number;
    }

    public function 
jsonSerialize() {
        return 
$this->number;
    }
}

echo 
json_encode(new IntegerValue(1), JSON_PRETTY_PRINT);
?>

上の例の出力は以下となります。

1

例4 JsonSerializable::jsonSerialize() で文字列を返す例

<?php
class StringValue implements JsonSerializable {
    public function 
__construct($string) {
        
$this->string = (string) $string;
    }

    public function 
jsonSerialize() {
        return 
$this->string;
    }
}

echo 
json_encode(new StringValue('Hello!'), JSON_PRETTY_PRINT);
?>

上の例の出力は以下となります。

"Hello!"


忘却曲線を使ってこの知識を確実に記憶に残す

フォーラムで「JsonSerializable::jsonSerialize - JSON にシリアライズしたいデータを指定する」について話す
各種マニュアル: PHPマニュアル | PEARマニュアル | Smarty(英語)マニュアル | PHP-GTKマニュアル | JsonSerializable::jsonSerialize - JSON にシリアライズしたいデータを指定する」をGoogle検索
copyright © 1997-2022 PHP ドキュメント作成グループ(ライセンス). provided by php spot. マニュアル: