如何知道promise的catch没写?

function p(){
    return new Promise((resolve, reject) => {
        reject();
    });
}

p().then(()=>{
    console.log(1);
})

重新编辑了下问题, 就是想问p()的.catch()我不写, 函数p内部要如何写浏览器才能不报错

阅读 4.4k
1 个回答

两个问题:
1.return 不是 retrun
2.new Promise后需要加一个括号

故原代码如下

var x = 10;
function p() {
    return new Promise((resolve, reject)=>{
        if(1 < x) {
            resolve();
        }
        if(5 < x) {
            reject();
        }
    });
}
p().then(() => {
    alert(1)
})

这样调用不会出问题, 另外1<x 过后又去判断 5<x, 后面那个if完全没必要, 不会执行的. 原因是promise的状态只能改变一次.第二次改变不会有效的.
即使是reject()执行了,promise的抛错也是promise的事,与P函数无关,promise的抛错只能在promise后面加catch语句捕获.由于p函数返回了new出来的promise,故在p函数执行结果后面加catch语句即可.
推荐看下这篇文章: Promise使用手册

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