PHP json格式和js json格式 js跨域調用實現代碼

來源:互聯網
上載者:User

先看一個js函數 複製代碼 代碼如下: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]);
}

這個函數,第一個alert(json[1].username); 會提示 “candy”。 json 變數是一個數組對象。所以要採用 obj.username 這樣的格式來調用。
第二個 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是一個數組,我們採用 json_encode 將$arr 轉換為了 json 格式 。
這段代碼會輸出:

[{"catid":"4","catname":"\u7a0b\u7a0b","meta_title":"\u7a0b\u7a0b\u535a\u5ba2"},{"catid":"6","catname":"climber","meta_title":"\u6500\u767b\u8005"}]
這就是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 檔案

代碼如下: 複製代碼 代碼如下:$arr = array (
array (
'catid' => '4',
'catname' => '程程',
'meta_title' => '程程部落格'
),

array (
'catid' => '6',
'catname' => 'climber',
'meta_title' => '攀登者',
)
);
$jsonstr = json_encode($arr);
-----下面寫在php區間之外-----
var jsonstr=< ? = $jsonstr ? >;

PS:在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) 就會 提示 “程程”和“climber”
這樣也實現了js跨域調用。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.