JsonSerializable::jsonSerialize

(PHP 5 >= 5.4.0)

JsonSerializable::jsonSerializeSpécifie les données qui doivent être linéarisées en JSON

Description

abstract public mixed JsonSerializable::jsonSerialize ( void )

Linéarise l'objet en une valeur qui peut être linéarisé nativement par la fonction json_encode().

Liste de paramètres

Cette fonction ne contient aucun paramètre.

Valeurs de retour

Retourne les données qui peuvent être linéarisées par la fonction json_encode(), qui peuvent être des valeurs de n'importe quel type autre qu'une ressource.

Exemples

Exemple #1 Exemple avec JsonSerializable::jsonSerialize() retournant un tableau

<?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);
?>
<?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);
?>
<?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);
?>
<?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);
?>

L'exemple ci-dessus va afficher :

"Hello!"

LoadingChargement en cours