| 
       
	某网站后台用php脚本得到一个JSON格式的数据,交给前台javascript进行处理,使用JSON实现数据的跨域调用. 
	后台profile.php代码如下: 
	
		- 
			<?php   
 
		- 
			$arr = array(   
 
		- 
			    'firstname' => iconv('gb2312', 'utf-8', '非诚'),   
 
		- 
			    'lastname' => iconv('gb2312', 'utf-8', '勿扰'),   
 
		- 
			    'contact' => array(   
 
		- 
			        'email' =>'fcwr@www.vcphp.com',   
 
		- 
			        'website' =>'http://www.vcphp.com',   
 
		- 
			    )   
 
		- 
			);   
 
		- 
			 
 
		- 
			$json_string = json_encode($arr);  
 
		- 
			 
 
		- 
			echo "getProfile($json_string)"; 
 
		- 
			?>  
 
	 
 
	需要指出的是,在非UTF-8编码下,中文字符将不可被encode,结果会出来空值,所以,如果你使用 gb2312编写PHP代码,那么就需要将包含中文的内容使用iconv或者mb转为UTF-8再进行json_encode. 
	前台index.html代码如下: 
	
		- 
			<script type="text/javascript">  
 
		- 
			function getProfile(str) {   
 
		- 
			    var arr = str;   
 
		- 
			    document.getElementById("firstname").innerHTML = arr.firstname;   
 
		- 
			}   
 
		- 
			</script>  
 
		- 
			<body> 
 
		- 
			<div id="firstname"></div> 
 
		- 
			</body>  
 
		- 
			 
 
		- 
			<script type="text/javascript" src="profile.php"></script> 
 
	 
 
	将JSON格式的数据直接赋值给javascript中的变量,就变成数组了,接下来操作起来就会非常的方便,此处如果使用XML做为数据传输,后续操作就不方便. 
	很显然,当index.html调用profile.php时,JSON字符串生成,并作为参数传入getProfile,然后将昵称插入到div 中,这样一次跨域数据交互就完成了调用index.html. 
      
      (责任编辑:最模板) |