$ .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 发回数据?