jquery的$getjson调用并获取远程的JSON字符串问题


Posted in Javascript onDecember 10, 2012

代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>无标题文档</title> 
</head> 
<script type="text/javascript" src="jquery-1.7.2.min.js"></script> 
<script type="text/javascript"> 
$(function(){ 
$("button").click(function(){ 
$.getJSON("ajax6.asp",function(data){ 
$("#pig").html(data.name); 
}); 
}); 
}); 
</script> 
<body> 
<button>click</button> 
<div id="pig"></div> 
</body> 
</html>

其中ajax6.asp为
<% 
response.Write(“{name:'peter',age:18}”); 
%>

为什么获取不了呢?,我想获取asp的json。
解决的关键问题是:key和value需要双引号,如下:
response.Write(“{“”name”":”"peter”",”"age”":”"18″”}”)

jQuery中常用getJSON来调用并获取远程的JSON字符串,将其转换为JSON对象,如果成功,则执行回调函数。原型如下:
jQuery.getJSON( url, [data], [callback] ) 跨域加载JSON数据。
url: 发送请求的地址
data : (可选) 待发送key/value参数
callback: (可选) 载入成功时的回调函数
主要用于客户端获取服务器JSON数据。简单示例:
服务器脚本,返回JSON数据:
// $.getJSON.php 
$arr=array("name"=>"zhangsan", "age"=>20); 
$jarr=json_encode($arr); 
echo $jarr;

注意两点:第一:在返回客户端之前,先用PHP函数json_encode将要返回的数据进行编码。第二:返回到客户端用的是echo,而不是return。
下面是核心的客户端代码:
<script language="javascript" type="text/javascript" src="./js/jquery.js"></script> 
<script language="javascript" type="text/javascript"> 
function getjs() 
{ 
$.getJSON("$.getJSON.php", {}, function(response){ 
alert(response.age); 
}); 
} 
<input type="button" name="btn" id="btn" value="test" onClick="javascript:getjs();"/>

由于在PHP中是用JSON编码返回值,所以此处必须用getJSON去调用PHP文件,从而获取数据。同时可以注意到,经由getJSON得到的数据已经变成了一个对象数组,可以用response.name,response.age很直观的获取返回值。
jquery提供了$.getJSON的方法,让我们可以实现跨域ajax请求,但jqueryAPI上的内容实在太少,如何用$.getJSON,请求网站应该返回怎样的数据库才能让$.getJSON获取到,下面我就用一个实际例子来说明下。
后端是用php的,以下代码主要实现的一个功能就是提供一个预约登记的接口,需要传入的数据分别有:用户姓名、联系电话和地址:
/*预约登记 执行 接口*/ 
case "yuyue_interface": 
$name = trim($_GET['name']); 
$phone = trim($_GET['phone']); 
$addr = trim($_GET['addr']); 
$dt = date("Y-m-d H:i:s"); 
$cb = $_GET['callback']; 
if($name == "" || $name == NULL){ 
echo $cb."({code:".json_encode(1)."})"; 
}elseif($phone == "" || $phone == NULL){ 
echo $cb."({code:".json_encode(2)."})"; 
}elseif($addr == "" || $addr == NULL){ 
echo $cb."({code:".json_encode(3)."})"; 
}else{ 
$db->execute("insert into tb_yuyue (realname,telphone,danwei,dt,ischeck) values ('$name','$phone','$addr','$dt',0)"); 
echo $cb."({code:".json_encode(0)."})"; 
} 
exit; 
break;

接着就是前端的处理了:
$(document).ready(function(){ 
//以下3个为预约登记需要的参数 
var name = "name"; //varchar类型,长度最多为8位(4个汉字) 
var phone = "phone"; //varchar类型,长度为11位 
var addr = "addr"; //varchar类型,长度最多为500位(250个汉字) 
$.getJSON("http://请求网站地址/data.php?ac=yuyue_interface&name="+name+"&phone="+phone+"&addr="+addr+"&callback=?", function(data){ 
if(data.code==1){ 
//自定义代码 
alert("姓名不能为空"); 
}else if(data.code==2){ 
//自定义代码 
alert("手机不能为空"); 
}else if(data.code==3){ 
//自定义代码 
alert("所在单位不能为空"); 
}else{ 
//自定义代码 
alert("预约成功"); 
} 
}); 
});

需要注意的是,在后端php代码里,必须把传递进来的" &callback=? "也输出来,如:
$cb = $_GET['callback']; 
echo $cb."({code:".json_encode(4)."})";

以上就是一个简单的$.getJSON试验,通过这个试验,我们可以学到如何用$.getJSON,也能学到如何做一个接口让别人跨域请求。
Javascript 相关文章推荐
Javascript SHA-1:Secure Hash Algorithm
Dec 20 Javascript
dwr spring的集成实现代码
Mar 22 Javascript
JavaScript 和 Java 的区别浅析
Jul 31 Javascript
jQuery实现table隔行换色和鼠标经过变色的两种方法
Jun 15 Javascript
浅谈js的setInterval事件
Dec 05 Javascript
详谈javascript中DOM的基本属性
Feb 26 Javascript
实现音乐播放器的代码(html5+css3+jquery)
Aug 04 Javascript
Bootstrap实现默认导航栏效果
Sep 21 Javascript
js省市县三级联动效果实例
Apr 15 Javascript
浅析javaScript中的浅拷贝和深拷贝
Feb 15 Javascript
详解vue+css3做交互特效的方法
Nov 20 Javascript
vue.js使用v-model实现父子组件间的双向通信示例
Feb 05 Javascript
如何用ajax来创建一个XMLHttpRequest对象
Dec 10 #Javascript
iframe 上下滚动条如何默认在下方实现原理
Dec 10 #Javascript
Ajax执行顺序流程及回调问题分析
Dec 10 #Javascript
js切换div css注意的细节
Dec 10 #Javascript
不同的jQuery API来处理不同的浏览器事件
Dec 09 #Javascript
addEventListener和attachEvent二者绑定的执行函数中的this不相同
Dec 09 #Javascript
Javascript获取窗口(容器)的大小及位置参数列举及简要说明
Dec 09 #Javascript
You might like
cache_lite试用
2007/02/14 PHP
php入门小知识
2008/03/24 PHP
分享一下贝贝成长进度的php代码
2012/09/14 PHP
关于PHP二进制流 逐bit的低位在前算法(详解)
2013/06/13 PHP
PHP获取网站中各文章的第一张图片的代码示例
2016/05/20 PHP
Zend Framework使用Zend_Loader组件动态加载文件和类用法详解
2016/12/09 PHP
在IIS下安装PHP扩展的方法(超简单)
2017/04/10 PHP
YII框架页面缓存操作示例
2019/04/29 PHP
JS中获取数据库中的值的方法
2013/07/14 Javascript
js父页面与子页面不同时显示的方法
2014/10/16 Javascript
js+HTML5基于过滤器从摄像头中捕获视频的方法
2015/06/16 Javascript
全面解析Javascript无限添加QQ好友原理
2016/06/15 Javascript
Vue.js每天必学之构造器与生命周期
2016/09/05 Javascript
JS数字千分位格式化实现方法总结
2016/12/16 Javascript
基于javascript的Form表单验证
2016/12/29 Javascript
javascript实现数据双向绑定的三种方式小结
2017/03/09 Javascript
在angularJs中进行数据遍历的2种方法
2018/10/08 Javascript
vuejs数据超出单行显示更多,点击展开剩余数据实例
2019/05/05 Javascript
15分钟学会vue项目改造成SSR(小白教程)
2019/12/17 Javascript
python实现文件名批量替换和内容替换
2014/03/20 Python
Python中Selenium模拟JQuery滑动解锁实例
2017/07/26 Python
Python设计模式之中介模式简单示例
2018/01/09 Python
Django分页查询并返回jsons数据(中文乱码解决方法)
2018/08/02 Python
Python爬虫自动化爬取b站实时弹幕实例方法
2021/01/26 Python
美国气象仪器、花园装饰和墙壁艺术商店:Wind & Weather
2019/05/29 全球购物
eBay英国购物网站:eBay.co.uk
2019/06/19 全球购物
Jar包的作用是什么
2014/03/30 面试题
化学专业毕业生自荐信
2013/11/15 职场文书
活动宣传策划方案
2014/05/23 职场文书
应届生求职自荐信
2014/07/04 职场文书
信用卡逾期证明示例
2014/09/13 职场文书
乡镇群众路线专项整治方案
2014/11/03 职场文书
《巨人的花园》教学反思
2016/02/19 职场文书
Python制作春联的示例代码
2022/01/22 Python
cypress测试本地web应用
2022/06/01 Javascript
Android学习之BottomSheetDialog组件的使用
2022/06/21 Java/Android