jQuery AJAX传JSON数据使用小结

2 篇文章 0 订阅
1 篇文章 0 订阅

  要使用jquery首先要引入jquery相应文件,下载jQuery(https://code.jquery.com),选择相应的版本,右键另存为……即可。
  在前端中引入jquery (我使用还是2.1.4版本):

<!--加载百度cdn jquery失败时使用本地的jquery-->
<script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
    !window.jQuery && document.write('<script src="js/jquery-2.1.4.min.js"><\/script>');
</script>

  封装要传输的数据:

function getFormData() 
{
    var json = 
    {
        "username": $("#username").val()
        , "pwd": $("#pwd").val()
    };
    return json;
}

1、$.ajax()

函数原型:$.ajax({name:value, name:value, … }):默认为异步请求。

$.ajax(
{
    type: "POST",
    url: "./JsonTestServlet",
    data: {jsonData: JSON.stringify(getFormData())},
    success: function(msg)
    {
        msg = eval("(" + msg + ")");
        //msg = JSON.parse(msg);
        alert(msg.username + " " + msg.pwd);
    },
    error: function(errmsg) 
    {
        alert("提交失败!");
    }
});

  这里必须转换一下,因为后台传来的json数据是以字符串形式传过来的。当然这里使用msg = JSON.parse(msg);也是可以的,JSON.parse()是将json数据从字符串中解析出来,而JSON.stringify()是将json数据转换成字符串。
   eval() 函数可解析字符串,并执行其中的的 JavaScript 代码。由于json数据是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。

2、$.get()

函数原型:$.get(url,data,function(data,status,xhr),dataType):使用POST方式来进行异步请求,后三个参数为可选。

$.get("./JsonTestServlet", {jsonData: JSON.stringify(getFormData())}, function(data) 
{
    data = JSON.parse(data);
    alert(data[0].username + data[0].pwd);
}); 

  这里也需要转换。

3、$.post()

函数原型:$.post(url,data,function(data,status,xhr),dataType):使用POST方式来进行异步请求,后三个参数为可选。

$.post("./JsonTestServlet", {jsonData: JSON.stringify(getFormData())}, function(info) 
{
    info = eval("(" + info + ")");
    alert(info.username + info.pwd);
}); 

  这里同样需要转换。

4、$.getJSON()

函数原型:$.getJSON(url,data,success(data,status,xhr)):使用GET方式来进行异步请求获取JSON数据,后两个参数可选。

$.getJSON("./JsonTestServlet", {jsonData: JSON.stringify(getFormData())}, function(data) 
{
    alert(data[0].username + data[0].pwd);
});

  这里不需要转换,因为$.getJSON()函数接收的就是json数据。

  *注: 在后台传输json数据时,我测试了单个json对象和json数组两种方式。总的来说接收方式没什么区别,但是在传输json数组时,前端接收转换的方式可以这样:info = eval(info);,也就是不加“()”也可以,原因是json数组是这样的[{},{},{},...],eval函数直接将json数组对象解析出来了。

参考资料

[1] jQuery AJAX 方法(http://www.runoob.com/jquery/jquery-ref-ajax.html)
[2] jquery eval解析JSON中的注意点介绍(http://www.jb51.net/article/40842.htm)

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值