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

2.8 KiB

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
5cdafbc32913098997531680 resolve と reject を使用してプロミスを完了する 1 301196 complete-a-promise-with-resolve-and-reject

--description--

プロミスには、pending (保留)、fulfilled (成功)、rejected (拒否) の 3 つの状態があります。 前のチャレンジで作成したプロミスは、プロミスの完了方法を追加していなかったために、永久に pending 状態のままになります。 プロミスを完了するには、プロミスの引数に与えられた resolve および reject パラメーターを使用します。 プロミスを成功としたい場合は resolve を使用し、失敗としたい場合は reject を使用します。 これらは、次に示すように引数を取るメソッドです。

const myPromise = new Promise((resolve, reject) => {
  if(condition here) {
    resolve("Promise was fulfilled");
  } else {
    reject("Promise was rejected");
  }
});

上記の例では、これらの関数の引数として文字列を使用していますが、実際には何でも使用できます。 多くの場合はオブジェクトで、そこからウェブサイトなどに設定するデータを取得して使用します。

--instructions--

プロミスを使用して成功と失敗を処理してください。 responseFromServertrue の場合は、resolve メソッドを呼び出してプロミスを成功として完了してください。 resolveには、We got the data という値の文字列を渡します。 responseFromServerfalse の場合は、代わりに reject メソッドを使用して文字列 Data not received を渡してください。

--hints--

if 条件が true の場合は、必要な文字列とともに resolve を呼び出す必要があります。

assert(
  code.match(/if\s*\(\s*responseFromServer\s*\)\s*{\s*resolve\s*\(\s*('|"|`)We got the data\1\s*\)(\s*|\s*;\s*)}/g)
);

if 条件が false の場合は、必要な文字列とともに reject を呼び出す必要があります。

assert(
  code.match(/}\s*else\s*{\s*reject\s*\(\s*('|"|`)Data not received\1\s*\)(\s*|\s*;\s*)}/g)
);

--seed--

--seed-contents--

const makeServerRequest = new Promise((resolve, reject) => {
  // responseFromServer represents a response from a server
  let responseFromServer;

  if(responseFromServer) {
    // Change this line
  } else {  
    // Change this line
  }
});

--solutions--

const makeServerRequest = new Promise((resolve, reject) => {
  // responseFromServer represents a response from a server
  let responseFromServer;

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