2016-09-03 5 views
0
私がフェッチしている

、それがスローエラー:reduxで非同期アクションからエラーをキャッチする方法はありますか?

fetchAuthorization(username, password) { 
    return fetch(`https://api.github.com/user`, { 
     method: 'GET', 
     headers: { 
      "Accept": 'application/json', 
      "Content-Type": 'application/json', 
      "Authorization": "Basic " + btoa(`${username}:${password}`) 
     }, 
    }) 
    .then(res => { 
     if(res.status !== 200) { 
      throw Error("Bad validation"); 
     } 
     return res.json(); 
    }); 
}, 

この非同期アクション(Reduxの):

export const onSignInAction = (username, password) => { 
    return dispatch => { 
     return api.fetchAuthorization(username, password) 
      .then(res => { 
       dispatch(signInAction(username, password, res)); 
      }) 
      .catch(err => console.log(err)); 
    } 
} 

次:

handleSignIn = (username, password) => { 
    const { onSignInAction } = this.props; 
    onSignInAction(username, password); 
} 

そして今、私は私のフェッチからキャッチエラーをしたいです:

handleSignIn =() => { 
    const { onSignIn } = this.props; 
    const { errorMessage, open } = this.state; 
    const username = this.usernameField.getValue(); 
    const password = this.passwordField.getValue(); 
    try { 
     onSignIn(username, password); 
    } 
    catch (Error) { 
     this.setState({ 
      errorMessage: 'Incorrect username or password' 
     }); 
    } 
} 

正しくキャッチするには?私のコードはこのようなことはしません。ありがとう!

+0

ためPromise.prototype.catch()に置き換えるには、 '=> '有効な構文戻り派遣ますか? – guest271314

+0

@ guest271314はい –

+0

'.catch()'から 'err'を'スローする 'ことを試みましたか? – guest271314

答えて

0

あなたは.catch()からthrowエラーができ、try..catch

var onSignInAction =() => { 
 
    return Promise.reject(new Error("Bad validation")).catch(e => { 
 
    console.log("catch 1", e.message); 
 
    throw e 
 
    }); 
 
} 
 

 
onSignInAction() 
 
.catch(err => { 
 
    console.log("catch 2:", { 
 
    errorMessage: 'Incorrect username or password' 
 
    }, err.message); 
 
});

+0

それは助けになりません –

+0

@ guest271314はい、それは動作します。ありがとう! –

関連する問題