获取$.post $.get回调函数返回值问题

您所在的位置:网站首页 get方法返回值有哪些 获取$.post $.get回调函数返回值问题

获取$.post $.get回调函数返回值问题

2024-02-20 19:45| 来源: 网络整理| 查看: 265

项目中用Jquery操作,肯定避免不了向服务器发送请求,所以就会用到上面的两个函数。完整的函数格式如下:

$.get(URL,callback); $.post(URL,data,callback);

而某些时候我们要用callback回调函数处理完以后的返回值,常规的思路是定义一个全局变量来接收返回值,然后在$post的外面,函数的里面返回即可。例如,下面为一个js函数:

function testAsync() { //定义一个全局变量来接受$post的返回值 var result; //调用一般处理程序 ; ;$.post("handler/QueryCourseByFirst.ashx", { Sqls: sql4 }, function (courseDT4) { result = courseDT4; }); return result; }

然后哪里需要这个函数就直接调用即可,例如: //调用函数

var res = testAsync();

看上去逻辑上貌似没问题,但试过就知道这样是存在问题的了,发现res通常取不到courseDT4。调试就会发现函数的执行顺序并不是顺序执行的。那么自然就想到了$.post发得请求为“异步”请求,所以发出请求后还没等一般处理程序处理返回结果,就执行了为res变量赋值,因此取到的值总为undefined。

经过查询,可以发现Jquery封装好的.post.get发得请求都为“异步”请求(最好查看一下Jquery的源码),当然上面的用于获取回调函数返回值的写法是错误的,只需将发送方式改为同步即可,即如下代码:

function testAsync() { //定义一个全局变量来接受$post的返回值 var result; //用ajax的“同步方式”调用一般处理程序 ; ;$.ajax({ url: "handler/QueryCourseByFirst.ashx", async: false,//改为同步方式 type: "POST", data: { Sqls: sql4 }, success: function (courseDT4) { result = courseDT4; } }); return result; }

然后再直接调用函数就没有问题了,如下:

//调用函数

var res = testAsync();


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3