账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    Promise里在延时器里throw new Error,为什么不能被后面的reject回调或者catch捕获?
    29
    0

    throw new Error语句放延时函数里,只会报错,不执行reject函数或者catch函数

    var promise = new Promise((resolve, reject) => {
        setTimeout(() => {
            throw new Error('nono') //这里主动抛出错误
        }, 500);
    })
        .then(()=>{},(err)=>{
            console.log(1) //这里是reject时应该调用的函数,但是这里并没有执行,只会在控制台报错
            console.log(err) //根本不执行这里
        })
        .catch((err)=>{
            console.log(2) //这里catch都不执行
            console.log(err)
        })

    而我不把throw new Error语句放延时函数里,就能在reject函数里执行

    var promise = new Promise((resolve, reject) => {
        throw new Error('nono') //这里直接抛出错误,就能被后面的reject函数执行到
    })
        .then(()=>{},(err)=>{
            console.log(1) //这里就执行了
            console.log(err)
        })
        .catch((err)=>{
            console.log(2)
            console.log(err)
        })

    另外,不用throw new Error,而是直接reject(),不论是否放在延时函数里都能正常被捕获

    var promise = new Promise((resolve, reject) => {
        setTimeout(() => {
            reject('hehe')
        }, 500);
    })
        .then(()=>{},(err)=>{
            console.log(1) //可以捕获
            console.log(err)
        })
        .catch((err)=>{
            console.log(2)
            console.log(err)
        })
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部