* chore(i8n,learn): processed translations * Update curriculum/challenges/chinese/01-responsive-web-design/applied-visual-design/use-the-u-tag-to-underline-text.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> Co-authored-by: Crowdin Bot <support+bot@crowdin.com> Co-authored-by: Nicholas Carrigan (he/him) <nhcarrigan@gmail.com> Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com>
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						|
id: 5cdafbd72913098997531681
 | 
						|
title: Maneja una promesa cumplida usando then
 | 
						|
challengeType: 1
 | 
						|
forumTopicId: 301203
 | 
						|
dashedName: handle-a-fulfilled-promise-with-then
 | 
						|
---
 | 
						|
 | 
						|
# --description--
 | 
						|
 | 
						|
Las promesas son muy útiles, cuando tu tienes un proceso que toma una cantidad de tiempo desconocida en tu código (algo asíncrono por ejemplo), a menudo una petición de servidor. Cuando tu haces una petición a un servidor, toma algo de tiempo, después de que termina, normalmente quieres hacer algo con la respuesta del servidor. Esto se puede lograr utilizando el método `then`. El método `then`, se ejecuta inmediatamente después de que tu promesa se cumple con `resolve`. A continuación un ejemplo:
 | 
						|
 | 
						|
```js
 | 
						|
myPromise.then(result => {
 | 
						|
 | 
						|
});
 | 
						|
```
 | 
						|
 | 
						|
`result` viene con el argumento proporcionado al método `resolve`.
 | 
						|
 | 
						|
# --instructions--
 | 
						|
 | 
						|
Añade el método `then` a tu promesa. Usa `result` como parámetro de tu función callback, asimismo imprime `result` en la consola.
 | 
						|
 | 
						|
# --hints--
 | 
						|
 | 
						|
Debes llamar al método `then` en la promesa.
 | 
						|
 | 
						|
```js
 | 
						|
assert(
 | 
						|
  __helpers.removeWhiteSpace(code).match(/(makeServerRequest|\))\.then\(/g)
 | 
						|
);
 | 
						|
```
 | 
						|
 | 
						|
El método `then`, debe tener una función callback con `result` como parámetro.
 | 
						|
 | 
						|
```js
 | 
						|
assert(resultIsParameter);
 | 
						|
```
 | 
						|
 | 
						|
Debes imprimir `result` en la consola.
 | 
						|
 | 
						|
```js
 | 
						|
assert(
 | 
						|
  resultIsParameter &&
 | 
						|
    __helpers
 | 
						|
      .removeWhiteSpace(code)
 | 
						|
      .match(/\.then\(.*?result.*?console.log\(result\).*?\)/)
 | 
						|
);
 | 
						|
```
 | 
						|
 | 
						|
# --seed--
 | 
						|
 | 
						|
## --after-user-code--
 | 
						|
 | 
						|
```js
 | 
						|
const resultIsParameter = /\.then\((function\(result\){|result|\(result\)=>)/.test(__helpers.removeWhiteSpace(code));
 | 
						|
```
 | 
						|
 | 
						|
## --seed-contents--
 | 
						|
 | 
						|
```js
 | 
						|
const makeServerRequest = new Promise((resolve, reject) => {
 | 
						|
  // responseFromServer is set to true to represent a successful response from a server
 | 
						|
  let responseFromServer = true;
 | 
						|
 | 
						|
  if(responseFromServer) {
 | 
						|
    resolve("We got the data");
 | 
						|
  } else {  
 | 
						|
    reject("Data not received");
 | 
						|
  }
 | 
						|
});
 | 
						|
```
 | 
						|
 | 
						|
# --solutions--
 | 
						|
 | 
						|
```js
 | 
						|
const makeServerRequest = new Promise((resolve, reject) => {
 | 
						|
  // responseFromServer is set to true to represent a successful response from a server
 | 
						|
  let responseFromServer = true;
 | 
						|
 | 
						|
  if(responseFromServer) {
 | 
						|
    resolve("We got the data");
 | 
						|
  } else {  
 | 
						|
    reject("Data not received");
 | 
						|
  }
 | 
						|
});
 | 
						|
 | 
						|
makeServerRequest.then(result => {
 | 
						|
  console.log(result);
 | 
						|
});
 | 
						|
```
 |