freeCodeCamp/curriculum/challenges/italian/02-javascript-algorithms-an.../es6/complete-a-promise-with-res...

2.5 KiB

id title challengeType forumTopicId dashedName
5cdafbc32913098997531680 Completare una promise con resolve e reject 1 301196 complete-a-promise-with-resolve-and-reject

--description--

Una promise ha tre stati: pending (in attesa), fulfilled (soddisfatta) e rejected (rifiutata). La promise che hai creato nell'ultima sfida è bloccata per sempre nello stato pending perché non hai aggiunto un modo per completarla. I parametri resolve e reject forniti all'argomento della promise vengono utilizzati per farlo. resolve è usato quando vuoi che la promise abbia successo, e reject è usato quando vuoi che la promise fallisca. Questi sono metodi che prendono un argomento, come si vede qui sotto.

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

L'esempio di cui sopra utilizza stringhe come argomento di queste funzioni, ma essi possono davvero essere qualsiasi cosa. Spesso potrebbe essere un oggetto, di cui potresti voler utilizzare i dati per metterli sul tuo sito web o altrove.

--instructions--

Fai sì che la promise gestisca il successo e il fallimento. Se responseFromServer è true, chiama il metodo resolve per completare con successo la promise. Passa a resolve una stringa di valore We got the data. Se invece responseFromServer è false, utilizza il metodo reject e passagli la stringa: Data not received.

--hints--

resolve dovrebbe essere chiamato con la stringa prevista quando la condizione dell'if è true.

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

reject dovrebbe essere chiamato con la stringa prevista quando la condizione dell'if è false.

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");
  }
});