json 格式與PHP json 格式

以前轉過一篇關於json格式 的文章。今天再重新整理個json格式的例子,以及php json格式與js json之間的調用。

我們先來看個js函數,

  1. function  jsontest()  
  2. {  
  3.     var  json = [{ 'username' : '張三' , 'userage' : '20' },{ 'username' : '李四' , 'userage' : '30' }];  
  4.     alert(json[1].username);  
  5.   
  6.     var  json2 = [[ '張三' , '20' ],[ '李四' , '30' ]];  
  7.     alert(json2[0][0]);  
  8. }  

這個函數,第一個alert(json[1].username); 會提示 “李四”。 json 變量是一個數組對象。所以要採用 obj.username 這樣的格式來調用。

第二個 alert(json2[0][0]);  會提示 “張三”。 json2變量是完全的一個json格式。 json和json2變量都達到了相同的效果,但json2明顯要比json精簡了很多。

這是 JavaScript json 格式

下面我們來看看php 與json格式。

先來看一段代碼

  1. $arr  =  array  (  
  2.   array  (  
  3.       'catid'  =>  '4' ,  
  4.       'catname'  =>  '招聘信息' ,  
  5.       'meta_title'  =>  '招聘信息標題'   
  6.     ),  
  7.   
  8.     array  (  
  9.       'catid'  =>  '55' ,  
  10.       'catname'  =>  '<span class="wp_keywordlink"><a href="http://www.gosoa.com.cn/" title="php開發">php</a></span>教程' ,  
  11.       'meta_title'  =>  'php教程標題' ,  
  12.     )  
  13. );  
  14. $jsonstr  = json_encode( $arr );  
  15. 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 格式 。

這段代碼會輸出

  1. [{ "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 文件

代碼如下:

  1.  <?php  
  2. $arr  =  array  (  
  3.  array  (  
  4.  'catid'  =>  '4' ,  
  5.  'catname'  =>  '招聘信息' ,  
  6.  'meta_title'  =>  '招聘信息標題'   
  7.  ),  
  8.   
  9.  array  (  
  10.  'catid'  =>  '55' ,  
  11.  'catname'  =>  'php教程' ,  
  12.  'meta_title'  =>  'php教程標題' ,  
  13.  )  
  14. );  
  15. $jsonstr  = json_encode( $arr );  
  16. ?>  
  17. 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 文件
代碼如下:

  1. <script type= "text/javascript"  src= "php_json.php" ></script>  
  2. <script language="javascript"  type= "text/javascript" >  
  3. function  loadjson(_json)  
  4. {  
  5.  if (_json)  
  6.  {  
  7.  for ( var  i=0;i<_json.length;i++)  
  8.  {  
  9.  alert(_json[i].catname);  
  10.  }  
  11.  }  
  12. }   
  13.   
  14. loadjson(jsonstr)  
  15. </script>  

這樣,我們在查看 json.html的時候,loadjson(jsonstr) 就會 提示 “招聘信息”和“php教程”

這樣也實現了js跨域調用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章