Это старая версия документа!
ПРОМИСИ
Виконання відкладених задач. Асінхронно.
Состояния промиса
- ожидание (panding)
- исполнен (resolve)
- отклонен (reject)
обявление промиса
const myPromise = new Promise ((resolve, reject)=>{
//Віполнение асинхронного действия нужно в результате візвать одну из функций resolve или reject
})
Получение резуьтата промиса
myPromse
.then(value => {
//действие в случае успешного віполнения
})
.catch (error=>{
//дія у випадку помилки
})
- Приклад 1
const isSuccess = true;
const promise = new Promise((resolve, reject) => {
setTimeout(() => {
if (isSuccess) {
resolve("Success! Value passed to resolve function");
} else {
reject("Error! Error passed to reject function");
}
}, 2000);
});
console.log(promise); // Об'єкт промісу
У змінну promise буде записаний проміс (об'єкт) у стані pending, а через дві секунди, щойно буде викликаний resolve() або reject(), проміс перейде у стан fulfilled або rejected, і ми зможемо його обробити.
- Приклад 2 (web)
fetch('https://jsonplaceholder.typicode.com/todos')
.then(response => {
console.log(response) // показує поний склад відповіді від серверу (з тех.дннними)
return response.json() //поверта тільки данні після ковераації з json
})
.then(json => console.log(json))
.catch(error => console.log(error.message))
- Приклад 3 (node.js)
const getData =(url)=>
new Promise ((resolve, reject)=>
fetch(url)
.then(response=>response.json())
.then(json => resolve(json))
.catch(error=>reject(error))
)
getData('https://jsonplaceholder.typicode.com/todos')
.then(data=>console.log(data))
.catch(error=>console.log(error))