JAVA、PHP、前端、APP、网站开发 - 开发技术学习

开发技术学习 » 编程开发 » PHP json格式和js json格式-js跨域调用

PHP json格式和js json格式-js跨域调用

此文被围观2595 日期: 2013-06-06 分类 : 编程开发  标签:  ········
整理一个json格式的例子,以及php json格式与js json之间的调用(传说中的js跨域调用)。 先看一个js函数
1 function jsontest()
2 {
3     var json = [{'username':'crystal','userage':'20'},{'username':'candy','userage':'24'}];
4     alert(json[1].username);
5
6     var json2 = [['crystal','20'],['candy','24']];
7     alert(json2[0][0]);
8 }
这个函数,第一个alert(json[1].username); 会提示 “candy”。 json 变量是一个数组对象。所以要采用 obj.username 这样的格式来调用。 第二个 alert(json2[0][0]); 会提示 “crystal”。 json2变量是完全的一个json格式。 json和json2变量都达到了相同的效果,但json2明显要比json精简了很多。 这是 JavaScript 的json 格式。 下面我们来看看php中的json格式。 还是先看一段代码
01 $arr = array (
02   array (
03       'catid' => '4',
04       'catname' => '程程',
05       'meta_title' => '程程博客'
06     ),
07
08     array (
09       'catid' => '6',
10       'catname' => 'climber',
11       'meta_title' => '攀登者',
12     )
13 );
14 $jsonstr = json_encode($arr);
15 echo $jsonstr;
这段代码中,$arr是一个数组,我们采用 json_encode 将$arr 转换为了 json 格式 。 这段代码会输出:
[{"catid":"4","catname":"u7a0bu7a0b","meta_title":"u7a0bu7a0bu535au5ba2"},{"catid":"6","catname":"climber","meta_title":"u6500u767bu8005"}]
这就是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 文件 代码如下:
01 $arr = array (
02   array (
03       'catid' => '4',
04       'catname' => '程程',
05       'meta_title' => '程程博客'
06     ),
07
08     array (
09       'catid' => '6',
10       'catname' => 'climber',
11       'meta_title' => '攀登者',
12     )
13 );
14 $jsonstr = json_encode($arr);
15 -----下面写在php区间之外-----
16 var jsonstr=< ? = $jsonstr ? >;
PS:在php_json.php文件末尾 var jsonstr=< ? = $jsonstr ? >; 这一句。 这是将json格式的数据赋值给 jsonstr 变量。 我们再建立一个 json.html 文件 代码如下:
01 <script type="text/javascript" src="php_json.php"></script><scripttype="text/javascript" language="javascript">
02 function loadjson(_json)
03 {
04  if(_json)
05  {
06  for(var i=0;i<_json.length;i++)
07  {
08  alert(_json[i].catname);
09  }
10  }
11 }
12
13 loadjson(jsonstr)
14 </script>
这样,我们在查看 json.html的时候,loadjson(jsonstr) 就会 提示 “程程”和“climber” 这样也实现了js跨域调用。

站点声明:部分内容源自互联网,为传播信息之用,如有侵权,请联系我们删除。

© Copyright 2011-2024 www.kfju.com. All Rights Reserved.
超级字帖 版权所有。 蜀ICP备12031064号      川公网安备51162302000234