标签:json
<span style="font-size:12px;">function testJson() {
	var jsonData = {
		"firstName" : "John",
		"lastName" : "Doe",
		"age" : 23
	};
	var employees = {
		"accounting" : [// accounting is an array in employees.
		{
			"firstName" : "John", // First element
			"lastName" : "Doe",
			"age" : 23
		}, {
			"firstName" : "Mary", // Second Element
			"lastName" : "Smith",
			"age" : 32
		}], // End "accounting" array.
		"sales" : [// Sales is another array in employees.
		{
			"firstName" : "Sally", // First Element
			"lastName" : "Green",
			"age" : 27
		}, {
			"firstName" : "Jim", // Second Element
			"lastName" : "Galley",
			"age" : 41
		}] // End "sales" Array.
	}// End Employees
	alert(employees.sales[1].firstName);//
	alert(employees.sales[1]["lastName"]);
}</span>
通过AJAX接收JSON数据
通过AJAX接收JSON数据有三个不同方式.委派,回调与解释.
通过委派得到JSON
 
这个方法没有标准命名约定,不过"委派法"倒是一个挺好的描述名字,因为服务器创建的javascript表达式文件会把JSON分派到一个变量 中.当把服务器的返回文本作为参数传给eval函数时,someVar变量就会装载JSON对象,然后你就可以通过这个变量访问.
var JSONFile = "someVar = { ‘color‘ : ‘blue‘ }";  // example of what is received from the server.服务器返回数据示例
eval(JSONFile); // Execute the javascript code contained in JSONFile.执行JSONFile中的javascript代码.
document.writeln(someVar.color); // 输出‘blue‘
 
通过回调得到JSON
 
第二个方法预先定义一个以JSON数据作为参数的函数,然后服务器返回的javascript表达式中调用这个函数.这个方法叫"回调法".这个方式被广泛地应用在处理第三方JSON数据中(例如,从其它域名获取的JSON数据)
function processData(incommingJSON) {
   document.writeln(incommingJSON.color); // 输出‘blue‘
}
// example of what is received from the server...
var JSONFile = "processData( { ‘color‘ : ‘blue‘ } )";
eval(JSONFile);
 
标签:json
原文地址:http://blog.csdn.net/michael10001/article/details/31433517