如何兑现承诺并发现错误

时间:2018-07-02 11:21:13

标签: javascript reactjs redux

我正在尝试使用webgazer.js用户,我的代码基本上会检查webgazer是否已初始化,并且在初始化时它将解析一个诺言,该诺言将调度一个动作。这是可行的,但是例如,如果没有网络摄像头,我需要抛出一个错误。我的代码中的错误永远不会被调用。

这是我的代码

export function detectJsCamera() {
    return async(dispatch) => {
        dispatch({type: types.JS_DETECTING_CAMERA});
        try {
            await detectCamera();
            await dispatch({type: types.JS_CAMERA_DETECTED});
        } catch (error) {
            await dispatch({type: types.CAMERA_DETECTION_FAILED, error: error.message});
            throw error;
        // this.props.history.push('/setup/positioning')
    };
    }
}

const detectCamera = () => new Promise((resolve, reject) => {
    const checkIfReady = () => {
        if (webgazer.isReady()) {
        resolve('success');
        } else {
            console.log('called')
        setTimeout(checkIfReady, 100);
        }
    }
    setTimeout(checkIfReady,100);
});

2 个答案:

答案 0 :(得分:0)

您需要拒绝才能引发如下异常

const detectCamera = () => new Promise((resolve, reject) => {
    const checkIfReady = () => {
        if (webgazer.isReady()) {
            resolve('success');
        } else {
            console.log('called');
            reject("some error");
        }
    }
    setTimeout(checkIfReady,100);
});

答案 1 :(得分:0)

当未初始化Webgazer时,您需要在detectCamera方法中调用 reject(),否则它将被detectJsCamera方法的catch块捕获。