当前位置: 首页 > 面试题库 >

JavaScript承诺-拒绝与抛出

贺华容
2023-03-14
问题内容

我已经阅读了几篇有关该主题的文章,但是我仍然不清楚是否Promise.reject与抛出错误之间有区别。例如,

使用Promise.reject

return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            return Promise.reject(new PermissionDenied());
        }
    });

使用抛出

return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            throw new PermissionDenied();
        }
    });

我倾向于仅使用throw它,因为它更短,但我想知道一个相对于另一个是否有任何优势。


问题答案:

使用一个相对于另一个没有优势,但是,在特定情况下throw无法使用。但是,这些情况可以解决。

每当您进入promise回调时,都可以使用throw。但是,如果您在任何其他异步回调中,则必须使用reject

例如,这不会触发捕获:

new Promise(function() {

  setTimeout(function() {

    throw 'or nah';

    // return Promise.reject('or nah'); also won't work

  }, 1000);

}).catch(function(e) {

  console.log(e); // doesn't happen

});

相反,您将面临未解决的承诺和未捕获的异常。在这种情况下,您可能想要使用reject。但是,您可以通过两种方式解决此问题。

  1. 通过使用超时内的原始Promise拒绝功能:
new Promise(function(resolve, reject) {

      setTimeout(function() {

        reject('or nah');

      }, 1000);

    }).catch(function(e) {

      console.log(e); // works!

    });
  1. 通过通知超时:
    function timeout(duration) { // Thanks joews

      return new Promise(function(resolve) {

        setTimeout(resolve, duration);

      });

    }



    timeout(1000).then(function() {

      throw 'worky!';

      // return Promise.reject('worky'); also works

    }).catch(function(e) {

      console.log(e); // 'worky!'

    });


 类似资料:
  • 问题内容: 在下面的代码中: 从api 使用(in )和使用抛出错误(in )有什么区别? 完全一样吗? 如果相同,为什么我们需要回调呢? 问题答案: 从api 使用(in )和使用抛出错误(in )有什么区别? 是的,当是回调时,您不能异步使用。例如,一些超时: 完全一样吗? 不,至少在您的语句后面跟随其他代码时才不会。立即完成解析程序功能,同时调用继续正常执行-在“标记”了承诺被拒绝之后。 此

  • 问题内容: 我在理解为什么拒绝不通过承诺链传递时遇到问题,我希望有人能够帮助我理解原因。对我来说,将功能附加到承诺链上意味着我有意要实现的原始承诺。很难解释,所以让我先显示我的问题的代码示例。(注意:此示例使用的是Node和延迟的节点模块。我使用Dojo 1.8.3对此进行了测试,并得到了相同的结果) 运行此操作的结果是以下输出: 好吧,对我来说,这个结果没有意义。通过附加到这个承诺链,每个人都暗

  • 问题内容: 我正在尝试用正确的方法表示正确的方法,以指示内发生故障。 如果诺言没有失败,(即返回诺言的操作是否正常工作,例如返回状态200的AJAX请求),但是我认为结果无效,通常我会这样做弹出窗口,向用户说明问题,然后执行“返回假”;尽早退出该方法。 但是,有了承诺,如果我想从.then()内部做类似的事情,我就被引导去相信我应该做的是抛出一个错误,而应该让它被.catch()抓住。 ),我已经

  • 问题内容: 我需要创建链式承诺: 如果我将errorCallback放在第一个中,则第二个将被解析,并调用其successCallback。但是,如果我删除了,那么第二个承诺将被拒绝。 根据Angular JS的文档,传播拒绝的唯一方法是返回并且它看起来并不明显,尤其是因为即使不需要它,我也必须注入服务。 也可以通过在中引发异常来完成此操作,但是它将异常跟踪写入控制台,这不好。 还有另一种选择可以

  • 问题内容: 我在理解为什么拒绝不通过承诺链传递时遇到问题,我希望有人能够帮助我理解原因。对我而言,将功能附加到承诺链上意味着我有意要实现的原始承诺。很难解释,所以让我先显示我的问题的代码示例。(注意:此示例使用的是Node和延迟的节点模块。我使用Dojo 1.8.3对此进行了测试,并得到了相同的结果) 运行此操作的结果是以下输出: 好吧,对我来说,这个结果没有道理。通过附加到该承诺链,每个人都暗示

  • 问题内容: 我从控制器内部的异步服务获取数据,如下所示: 我的问题: 当我从服务中获得错误而又不返回承诺时,如何再次查询服务。 在我的服务中这样做会更好吗? 谢谢! 问题答案: 您可以在服务本身而不是控制器中重试该请求。 因此,可能是这样的: 您可以摆脱控制器中的错误功能: