作家
登录

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

作者: 来源:www.28hudong.com 2013-03-30 00:18:31 阅读 我要评论

代码如下: 复制代码 代码如下: <!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,也能学到如何做一个接口让别人跨域请求。

  推荐阅读

  完全用CSS实现鼠标移动到图片并更换图片

CSS实现鼠标移动到图片,更换图片,这是一个完全用CSS实现的效果,当然用JavaScript也可以实现,当把鼠标移动到图片的时候,图片自动更换为其它的图片,由此我们可以制作一些效果复杂的按钮,比如换色按钮。 >>>详细阅读


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

地址:http://www.17bianji.com/kaifa2/JS/22830.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)