首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >AJAX与返回(异步相关)

AJAX与返回(异步相关)
EN

Stack Overflow用户
提问于 2014-04-11 04:29:30
回答 3查看 55关注 0票数 2

我的代码看起来是:

代码语言:javascript
复制
function DBManager() {

    this.getContactsList = function() {
        $.post('/post/getContactsList', function (contacts) {
            return contacts;
        });
    }
}

var DBManager = new DBManager();

console.log(FF_DBManager.getContactsList());

但我得到的是undefined,而不是从帖子的回复中看到结果。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-04-11 04:32:27

因为只有在ajax调用完成之后,联系人的值才会雪崩。因此,您需要通过一个回调函数来完成这个任务,这个回调函数处理ajax结果。喜欢

代码语言:javascript
复制
function DBManager() {

    this.getContactsList = function(cb) {
        $.post('/post/getContactsList', function (contacts) {
            cb(contacts);
        });
    }
}

FF_DBManager.getContactsList(function(data){

    console.log(data);

});
票数 1
EN

Stack Overflow用户

发布于 2014-04-11 04:54:48

我喜欢在这些情况下使用一个例子。

同步函数是这样工作的。你告诉你妻子你要出去买东西,给她一张空白的纸,让她把她要你买的东西写下来。你等她把它写下来,然后去商店。

异步函数是这样工作的。你告诉你的妻子你要出去购物,给她一张空白的纸,让她写下她想让你买的东西,等她买完后,把纸给你,让你去商店;你会等待她的指示。然后你忘记它,开始读你的晚报。

使用异步函数而不了解您所做的事情,就像您在最初的文章中所做的那样,您做了类似的事情。你告诉你的妻子你要出去购物,给她一张空白的纸,让她写下她想让你买的东西,等她买完后,把报纸给你,让你去商店。然后你立即去商店,当你找不到你妻子的文件时,你会感到困惑。你回家,继续读晚报。然后你的妻子给了你她的清单,并试图告诉你去商店,但你忽略了她,认为你的工作已经完成。

票数 2
EN

Stack Overflow用户

发布于 2014-04-11 04:45:28

当您进行函数调用时,该函数依次发出ajax请求,这基本上是一个异步请求。此时,返回将是undefined,但一旦ajax调用完成,它将返回正确的值。

代码语言:javascript
复制
function DBManager() {

    this.getContactsList = function() {
        $.post('/post/getContactsList', function (contacts) {
            console.log(contacts);
            return contacts;
        });
    }
}

var FF_DBManager = new DBManager();

console.log(FF_DBManager.getContactsList());

您可以尝试在回调方法中添加一个console.log(contacts);,以查看基本上返回了什么。

否则,如果您真的想使用ajax并等待返回,那么您可以尝试使ajax调用同步而不是异步。

$.ajax的一个简单示例

代码语言:javascript
复制
$.ajax({
  type: 'POST',
  url: url,
  data: data,
  success: success,
  dataType: dataType,
  async:false
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23003550

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档