以前轉過一篇關於json格式 的文章。今天再重新整理個json格式的例子,以及php json格式與js json之間的調用。
我們先來看個js函數,
- function jsontest()
- {
- var json = [{ 'username' : '張三' , 'userage' : '20' },{ 'username' : '李四' , 'userage' : '30' }];
- alert(json[1].username);
- var json2 = [[ '張三' , '20' ],[ '李四' , '30' ]];
- alert(json2[0][0]);
- }
這個函數,第一個alert(json[1].username); 會提示 “李四”。 json 變量是一個數組對象。所以要採用 obj.username 這樣的格式來調用。
第二個 alert(json2[0][0]); 會提示 “張三”。 json2變量是完全的一個json格式。 json和json2變量都達到了相同的效果,但json2明顯要比json精簡了很多。
這是 JavaScript 的json 格式 。
下面我們來看看php 與json格式。
先來看一段代碼
- $arr = array (
- array (
- 'catid' => '4' ,
- 'catname' => '招聘信息' ,
- 'meta_title' => '招聘信息標題'
- ),
- array (
- 'catid' => '55' ,
- 'catname' => '<span class="wp_keywordlink"><a href="http://www.gosoa.com.cn/" title="php開發">php</a></span>教程' ,
- 'meta_title' => 'php教程標題' ,
- )
- );
- $jsonstr = json_encode( $arr );
- echo $jsonstr ;
$arr = array (
array (
'catid' => '4',
'catname' => '招聘信息',
'meta_title' => '招聘信息標題'
),
array (
'catid' => '55',
'catname' => 'php
教程',
'meta_title' => 'php教程標題',
)
);
$jsonstr = json_encode($arr);
echo $jsonstr;
這段代碼中,$arr是一個數組,我們採用 json_encode 將$arr 轉換爲了 json 格式 。
這段代碼會輸出
- [{ "catid" : "4" , "catname" : "/u62db/u8058/u4fe1/u606f" , "meta_title" : "/u62db/u8058/u4fe1/u606f/u6807/u9898" },{ "catid" : "55" , "catname" : "php/u6559/u7a0b" , "meta_title" : "php/u6559/u7a0b/u6807/u9898" }]
[{"catid":"4","catname":"/u62db/u8058/u4fe1/u606f","meta_title":"/u62db/u8058/u4fe1/u606f/u6807/u9898"},{"catid":"55","catname":"php/u6559/u7a0b","meta_title":"php/u6559/u7a0b/u6807/u9898"}]
這就是php對於json數據的處理。
對於json數據,php 也可以採用 json_decode()函數將json數據轉換成 數組 。
比如 上述代碼中,我們採用json_decode函數處理下。又會打印出 上面的數組。
$jsonstr = json_encode($arr);
$jsonstr = json_decode($jsonstr);
print_r($jsonstr);
接下來,我們看看,php json數據和 js json數據如何相互調用。
我們新建一個 php_json.php 文件
代碼如下:
- <?php
- $arr = array (
- array (
- 'catid' => '4' ,
- 'catname' => '招聘信息' ,
- 'meta_title' => '招聘信息標題'
- ),
- array (
- 'catid' => '55' ,
- 'catname' => 'php教程' ,
- 'meta_title' => 'php教程標題' ,
- )
- );
- $jsonstr = json_encode( $arr );
- ?>
- var jsonstr=<?= $jsonstr ?>;
<?php
$arr = array (
array (
'catid' => '4',
'catname' => '招聘信息',
'meta_title' => '招聘信息標題'
),
array (
'catid' => '55',
'catname' => 'php教程',
'meta_title' => 'php教程標題',
)
);
$jsonstr = json_encode($arr);
?>
var jsonstr=<?=$jsonstr?>;
補充下,在php_json.php文件末尾 var jsonstr=<?=$jsonstr?>; 這一句。 這是將json格式的數據賦值給 jsonstr 變量。
我們再建立一個 json.html 文件
代碼如下:
- <script type= "text/javascript" src= "php_json.php" ></script>
- <script language="javascript" type= "text/javascript" >
- function loadjson(_json)
- {
- if (_json)
- {
- for ( var i=0;i<_json.length;i++)
- {
- alert(_json[i].catname);
- }
- }
- }
- loadjson(jsonstr)
- </script>
這樣,我們在查看 json.html的時候,loadjson(jsonstr) 就會 提示 “招聘信息”和“php教程”
這樣也實現了js跨域調用。