|
復制代碼 代碼如下:
function jsontest()
{
var json = [{'username':'crystal','userage':'20'},{'username':'candy','userage':'24'}];
alert(json[1].username);
var json2 = [['crystal','20'],['candy','24']];
alert(json2[0][0]);
}
這個函數(shù),第一個alert(json[1].username); 會提示 “candy”。 json 變量是一個數(shù)組對象。所以要采用 obj.username 這樣的格式來調(diào)用。
第二個 alert(json2[0][0]); 會提示 “crystal”。 json2變量是完全的一個json格式。 json和json2變量都達到了相同的效果,但json2明顯要比json精簡了很多。
這是 JavaScript 的json 格式。
下面我們來看看php中的json格式。
還是先看一段代碼
復制代碼 代碼如下:
$arr = array (
array (
'catid' => '4',
'catname' => '程程',
'meta_title' => '程程博客'
),
array (
'catid' => '6',
'catname' => 'climber',
'meta_title' => '攀登者',
)
);
$jsonstr = json_encode($arr);
echo $jsonstr;
這段代碼中,$arr是一個數(shù)組,我們采用 json_encode 將$arr 轉(zhuǎn)換為了 json 格式 。
這段代碼會輸出:
[{"catid":"4","catname":"/u7a0b/u7a0b","meta_title":"/u7a0b/u7a0b/u535a/u5ba2"},{"catid":"6","catname":"climber","meta_title":"/u6500/u767b/u8005"}]
這就是php對于json數(shù)據(jù)的處理。
對于json數(shù)據(jù),php 也可以采用 json_decode()函數(shù)將json數(shù)據(jù)轉(zhuǎn)換成 數(shù)組 。
比如 上述代碼中,我們采用json_decode函數(shù)處理下。又會打印出 上面的數(shù)組。
$jsonstr = json_encode($arr);
$jsonstr = json_decode($jsonstr);
print_r($jsonstr);
接下來,我們看看,php json數(shù)據(jù)和 js json數(shù)據(jù)如何相互調(diào)用。
我們新建一個 php_json.php 文件
代碼如下:
復制代碼 代碼如下:
$arr = array (
array (
'catid' => '4',
'catname' => '程程',
'meta_title' => '程程博客'
),
array (
'catid' => '6',
'catname' => 'climber',
'meta_title' => '攀登者',
)
);
$jsonstr = json_encode($arr);
-----下面寫在php區(qū)間之外-----
var jsonstr=< ? = $jsonstr ? >;
PS:在php_json.php文件末尾 var jsonstr=< ? = $jsonstr ? >; 這一句。 這是將json格式的數(shù)據(jù)賦值給 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) 就會 提示 “程程”和“climber”
這樣也實現(xiàn)了js跨域調(diào)用。
php技術(shù):PHP json格式和js json格式 js跨域調(diào)用實現(xiàn)代碼,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。