Files
2022-01-20 20:30:18 +01:00

2.3 KiB

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
5cdafbe72913098997531682 拒否されたプロミスを catch で処理する 1 301204 handle-a-rejected-promise-with-catch

--description--

catch は、プロミスが拒否されたときに使用するメソッドで、 プロミスの reject メソッドが呼び出された直後に実行されます。 構文は次のとおりです。

myPromise.catch(error => {

});

errorreject メソッドに渡される引数です。

--instructions--

catch メソッドをプロミスに追加してください。 error をコールバック関数のパラメーターとして使用し、コンソールに error を出力してください。

--hints--

プロミスで catch メソッドを呼び出す必要があります。

assert(
  __helpers.removeWhiteSpace(code).match(/(makeServerRequest|\))\.catch\(/g)
);

catch メソッドでは、error をパラメーターとするコールバック関数を記述する必要があります。

assert(errorIsParameter);

コンソールに error を出力する必要があります。

assert(
  errorIsParameter &&
    __helpers
      .removeWhiteSpace(code)
      .match(/\.catch\(.*?error.*?console.log\(error\).*?\)/)
);

--seed--

--after-user-code--

const errorIsParameter = /\.catch\((function\(error\){|error|\(error\)=>)/.test(__helpers.removeWhiteSpace(code));

--seed-contents--

const makeServerRequest = new Promise((resolve, reject) => {
  // responseFromServer is set to false to represent an unsuccessful response from a server
  let responseFromServer = false;

  if(responseFromServer) {
    resolve("We got the data");
  } else {  
    reject("Data not received");
  }
});

makeServerRequest.then(result => {
  console.log(result);
});

--solutions--

const makeServerRequest = new Promise((resolve, reject) => {
  // responseFromServer is set to false to represent an unsuccessful response from a server
  let responseFromServer = false;

  if(responseFromServer) {
    resolve("We got the data");
  } else {  
    reject("Data not received");
  }
});

makeServerRequest.then(result => {
  console.log(result);
});

makeServerRequest.catch(error => {
  console.log(error);
});