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逻辑。特别是在此示例中,没有任何内容。
done
现在我看到我已经混淆了两者。它们几乎是2种不同的东西。仅仅因为它们是异步的,并不意味着它们是可互换的。
==============
编辑2: 我发现一些有用的材料:
承诺反模式
您对Promise和Ajax调用感到困惑。它们有点像苹果和小刀。您可以用刀切一个苹果,而刀是可以应用到苹果上的工具,但是两者是完全不同的。
承诺是用于管理异步操作的工具。它们跟踪异步操作何时完成以及它们的结果,并让您与其他代码或其他异步操作协调该完成和那些结果(包括错误条件)。它们本身实际上并不是异步操作。Ajax调用是一种特定的异步操作,可以与传统的回调接口一起使用或包装在promise接口中。
Ajax调用是一种特定类型的异步操作。您可以使用使Ajax调用或者与传统的回调XMLHttpRequest接口,也可以使Ajax调用(在现代浏览器),使用与承诺fetch()接口。
XMLHttpRequest
fetch()
您没有显示您正在谈论的特定代码,但是有时您想启动异步操作1,然后在完成异步操作后,希望他们启动异步操作2(通常使用第一个操作的结果)。在这种情况下,通常将一个嵌套在另一个内部。
您的代码示例在这里:
被认为是一种承诺反模式。没有必要在此处创建新的诺言,因为$.getJSON()已经返回了您可以返回的诺言。您可以改为:
$.getJSON()
function threadsGet() { return $.getJSON('api/threads'); }
或者,如果您想将有些非标准的jQuery Promise“转换”为标准Promise,则可以执行以下操作:
function threadsGet() { return Promise.resolve($.getJSON('api/threads')); }