JSON JsonSerializable::jsonSerialize

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

JsonSerializable::jsonSerialize — JSON으로 직렬화해야 하는 데이터 지정


설명

public JsonSerializable::jsonSerialize(): mixed

객체를 json_encode()에 의해 기본적으로 직렬화할 수 있는 값으로 직렬화합니다.


매개변수

이 함수에는 매개변수가 없습니다.


반환 값

리소스가 아닌 모든 유형의 값인 json_encode()로 직렬화할 수 있는 데이터를 반환합니다.


Examples

예제 #1 배열을 반환하는 JsonSerializable::jsonSerialize() 예제

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

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

$array = [1, 2, 3];
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() int를 반환하는 예제

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