深入理解PHP JSON數(shù)組與對象
來源:易賢網 閱讀:1001 次 日期:2016-08-12 14:43:11
溫馨提示:易賢網小編為您整理了“深入理解PHP JSON數(shù)組與對象”,方便廣大網友查閱!

在PHP后端和客戶端數(shù)據交互的過程中,JSON數(shù)據中有時格式不定,一會兒是數(shù)組,一會兒是對象,弄得客戶端開發(fā)人員要崩潰的感覺。

因此,前后端相關人員先對PHP的json_encode函數(shù)原理有必要的了解是最重要的一個環(huán)節(jié)。

PHP中的array是個萬能的數(shù)據結構,并不像其它語言根據需要的場景會定義很多約束性的數(shù)據類型來描述結構,所以PHP程序員是很難給客戶端人員講清楚返回的是什么結構的數(shù)據的。

也就變成明明是通過PHP的數(shù)組數(shù)據編碼成json的,但輸出值有時是數(shù)組、有時是對象的情況。

<?php

/*

如果你想生成一個json格式的數(shù)組格式(Vector)而非對象格式(Map)的,那么數(shù)據的下標:

必須是數(shù)字索引,

必須從0開始,

必須從小到大依次增加、中間不可以跳躍、順序不可變動.

*/

//符合數(shù)組

$vector = [

12, 23, 18

];

echo json_encode($vector);

//符合數(shù)組

$vector2 = [

0 => 12, 1 => 23, 2 => 18

];

echo json_encode($vector2);

//不符合數(shù)組,下標有跳躍

$map = [

0 => 12, 1 => 23, 2 => 18, 4 => 20

];

echo json_encode($map);

//不符合數(shù)組,下標順序不對

$map = [

0 => 12, 1 => 23, 3 => 18, 2 => 20

];

echo json_encode($map);

//不符合數(shù)組,下標沒有從0開始

$map_1 = [

1 => '111', 2 => 'asdfa'

];

echo json_encode($map_1);

//典型的對象格式

$map_2 = ['abc' => 1, 'de' => 2, 'fi' => null];

echo json_encode($map_2);

/**

* 請注意上面的變量命名,對應于Hack中的概念,Vector和Map為兩種數(shù)據集合類型

* 如果你需要將"索引數(shù)組"強制轉化成"對象",可以這樣寫

* json_encode((object) $a);

* 或

* json_encode ($a, JSON_FORCE_OBJECT);

*

*/

解決方案是什么呢?

就是通過PHP封裝Vector和Map這兩種數(shù)據結構的類,在構造json輸出結構時,以這兩種類型做封裝和轉換,來確保結構的確定性。

以上所述是小編給大家介紹的PHP JSON數(shù)組與對象,希望對大家有所幫助

更多信息請查看網絡編程
易賢網手機網站地址:深入理解PHP JSON數(shù)組與對象
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網