JsonSerializable::jsonSerialize

(PHP 5 >= 5.4.0, PHP 7, PHP 8)

JsonSerializable::jsonSerialize指定需要被序列化成 JSON 的數(shù)據(jù)

說明

abstract public JsonSerializable::jsonSerialize(): mixed

序列化物體(Object)成能被 json_encode() 原生地序列化的值。

參數(shù)

此函數(shù)沒有參數(shù)。

返回值

返回能被 json_encode() 序列化的數(shù)據(jù), 這個值可以是除了 resource 外的任意類型。

范例

示例 #1 JsonSerializable::jsonSerialize() 例子 returning an array

<?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() 例子 返回了一個關聯(lián)數(shù)組 array

<?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() 例子 返回一個 integer

<?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() 例子 返回一個 string

<?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!"