深入理解PHP JSON數(shù)組與對象
在PHP后端和客戶端數(shù)據(jù)交互的過程中,JSON數(shù)據(jù)中有時格式不定,一會兒是數(shù)組,一會兒是對象,弄得客戶端開發(fā)人員要崩潰的感覺。
因此,前后端相關人員先對PHP的json_encode函數(shù)原理有必要的了解是最重要的一個環(huán)節(jié)。
PHP中的array是個萬能的數(shù)據(jù)結構,并不像其它語言根據(jù)需要的場景會定義很多約束性的數(shù)據(jù)類型來描述結構,所以PHP程序員是很難給客戶端人員講清楚返回的是什么結構的數(shù)據(jù)的。
也就變成明明是通過PHP的數(shù)組數(shù)據(jù)編碼成json的,但輸出值有時是數(shù)組、有時是對象的情況。
<?php /* 如果你想生成一個json格式的數(shù)組格式(Vector)而非對象格式(Map)的,那么數(shù)據(jù)的下標: 必須是數(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ù)據(jù)集合類型 * 如果你需要將"索引數(shù)組"強制轉化成"對象",可以這樣寫 * json_encode((object) $a); * 或 * json_encode ($a, JSON_FORCE_OBJECT); * */
解決方案是什么呢?
就是通過PHP封裝Vector和Map這兩種數(shù)據(jù)結構的類,在構造json輸出結構時,以這兩種類型做封裝和轉換,來確保結構的確定性。
以上所述是小編給大家介紹的PHP JSON數(shù)組與對象,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
THINKPHP3.2使用soap連接webservice的解決方法
這篇文章主要為大家詳細介紹了THINKPHP3.2使用soap連接webservice的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
laravel model模型定義實現(xiàn)開啟自動管理時間created_at,updated_at
今天小編就為大家整理了一篇laravel model模型定義實現(xiàn)開啟自動管理時間created_at,updated_at,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10

