Promise和AJAX有什么区别?
Promise和AJAX调用都是异步操作。两者都可以进行GET / POST请求。<< 编辑:那是错误的陈述
那么它们之间有什么区别呢?并且什么时候最好使用一个而不是另一个呢?
另外,还有一件事:
最近,我遇到了一个承诺,其中包含AJAX。为什么要在异步操作中放入异步操作?这就像在面包三明治中放一块面包。
function threadsGet() {return new Promise((resolve, reject) => {
$.getJSON('api/threads')
.done(resolve)
.fail(reject);
})
}
此处使用jQuery。并且AJAX调用具有Promise行为和属性。我没有早些得到,但是这里是我的想法:我们可以在Promise中做点什么。然后使用AJAX调用,并在done
函数中传递已解决的Promise逻辑。特别是在此示例中,没有任何内容。
现在我看到我已经混淆了两者。它们几乎是2种不同的东西。仅仅因为它们是异步的,并不意味着它们是可互换的。
==============
编辑2: 我发现一些有用的材料:
承诺反模式
回答:
您对Promise和Ajax调用感到困惑。它们有点像苹果和小刀。您可以用刀切一个苹果,而刀是可以应用到苹果上的工具,但是两者是完全不同的。
承诺是用于管理异步操作的工具。它们跟踪异步操作何时完成以及它们的结果,并让您与其他代码或其他异步操作协调该完成和那些结果(包括错误条件)。它们本身实际上并不是异步操作。Ajax调用是一种特定的异步操作,可以与传统的回调接口一起使用或包装在promise接口中。
那么它们之间有什么区别呢?并且什么时候最好使用一个而不是另一个呢?
Ajax调用是一种特定类型的异步操作。您可以使用使Ajax调用或者与传统的回调XMLHttpRequest
接口,也可以使Ajax调用(在现代浏览器),使用与承诺fetch()
接口。
最近,我遇到了一个承诺,其中包含AJAX。为什么要在异步操作中放入异步操作?这就像在面包三明治中放一块面包。
您没有显示您正在谈论的特定代码,但是有时您想启动异步操作1,然后在完成异步操作后,希望他们启动异步操作2(通常使用第一个操作的结果)。在这种情况下,通常将一个嵌套在另一个内部。
您的代码示例在这里:
function threadsGet() { return new Promise((resolve, reject) => {
$.getJSON('api/threads')
.done(resolve)
.fail(reject);
})
}
被认为是一种承诺反模式。没有必要在此处创建新的诺言,因为$.getJSON()
已经返回了您可以返回的诺言。您可以改为:
function threadsGet() { return $.getJSON('api/threads');
}
或者,如果您想将有些非标准的jQuery Promise“转换”为标准Promise,则可以执行以下操作:
function threadsGet() { return Promise.resolve($.getJSON('api/threads'));
}
以上是 Promise和AJAX有什么区别? 的全部内容, 来源链接: utcz.com/qa/432282.html