$ .post()之后的代码在post-request完成之前执行

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了$ .post()之后的代码在post-request完成之前执行相关的知识,希望对你有一定的参考价值。

我试图使用post请求(jQuery的$ .post)从服务器获取数据并将其分配给javascript变量。

代码如下:

function getData() {        
    var zones = DUMMY_zones;
    var workers = [];

    console.log("1");

    $.post('server/main.php', {info: 'req_workers'}, function(result) {
        var result = JSON.parse(result);

        console.log("2");

    });


    console.log("3");
    return [zones, workers];
}

然而奇怪的是,返回在$ .post请求完成之前执行,因此workers是未定义的变量。控制台输出如下:

ppe_c_js.js:82 1
ppe_c_js.js:90 3
ppe_c_js.js:85 2

如何顺序执行代码?

谢谢!

答案

你可以把jquery发布到synchronous。但这是一种不好的做法。因此,您的浏览器在操作期间将处于冻结状态。

$.ajax({
  type: 'POST',
  url: url,
  data: data,
  success: success,
  dataType: dataType,
  async:false
});

以上是关于$ .post()之后的代码在post-request完成之前执行的主要内容,如果未能解决你的问题,请参考以下文章

在 $http.post 之后使用 $http.get 重新加载控制器

在 node.js 中使用 pug 在表单“post”之后发送空

如何在 Qt 中的 HTTP Post 之后从 PHP 发回数据?

checkbox选择post之后进行处理

在使用 jquery .ajax() 重定向的 POST 之后获取实际 URL

OC HTTPRequest GET和POST请求的代码封装