如果Promise对象reject自身

代码:

            var der = {};

            var p = new Promise(function (resolve, reject) {
                der.reject = reject;
            })
            p.then((v) => {
                console.log('resolve');
                console.log(v);
            })
            p.catch(function (v) {
                console.log(v);
                console.log('reject');
                console.log(v);
            });

            der.reject(p);
            console.log(p);

火狐下只输出reject,chrome下正常输入,然后会出现Uncaught (in promise)

请问,为什么会出现未捕获的异常呢,p的catch明明定义了,而且为什么火狐下只输出reject,输出p的操作都无效果(实则应该也是出现异常未捕获导致)


补充:
出现未捕获的异常的原因是,虽然then中没定义第二个函数,但是仍然是运行then,并且将据因和状态传递给返回的新的Promise对象,返回的Promise对象没有catch回调,所以报出了异常
但是firefox中输出p无效果的原因仍然不清楚

阅读 2.5k
2 个回答
var der = {};

var p = new Promise(function (resolve, reject) {
    der.reject = reject;
})
// 下面修改成这个样子,因为then内部的处理函数也需要异常捕获
p.then((v) => {
    console.log('resolve');
    console.log(v);
}).catch(function (v) {
    console.log(v);
    console.log('reject');
    console.log(v);
});

der.reject(p);
console.log(p);

Promise相当于一个标准,符合标准的这种原型都可以称为promise,在标准之外的特性不同浏览器可能不一样,很显然,火狐认为.catch和.then可以分别声明,然后在运行时响应,也就是你上边提到的没报错;而谷歌则认为.catch要连同.then中的异常一同处理,所以需要作用在.then之后的promise上。你将.then().catch连用,谷歌就不会报错。深层次的原因也有可能一个是基于事件,一个是基于轮询导致的。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题