Power of async and Promise


/////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////// Async ////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////
// const promise = fetch('https://jsonplaceholder.typicode.com/todos')
// promise
// .then(res => res.json())
// .then(data => console.log(data))
// .catch(err => console.log(err))

const getBlogs = async (name) => {
const fruits = {
"one": "One 1",
"two": "Two 2",
"three": "Three 3"
}
await delay(2000);
return Promise.resolve(fruits[name]);
}

// for small
const makeMe = async () => {
try {
let a = getBlogs('one');
let b = getBlogs('two');
const final = Promise.all([a, b]);
// throw "error";
return final;
} catch (err) {
console.log(err);
return "we are going to fine";
// throw "Its broken"
}
}
makeMe()
.then(v => console.log(v))
.catch(error => { console.log(error) })

// For Multiple
const datas = ['one', 'two', 'three', 'one', 'two', 'three'];
const getDatas = async () => {
let temp = [];
for await (const v of datas) {
let a = getBlogs(v);
temp.push(a);
}
// Resolving all Promise in short
return Promise.all(temp);
}
getDatas().then(val => {
console.log(val);
});

/////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////// Promise ////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////////////////////
const testFun = (data) => {
return new Promise((resolve, reject) => {
setTimeout(() => {
if (data == 1) {
resolve('i');
} else {
reject('r');
}
}, 5000)
})
}

testFun(2).then(val => console.log(val))
.catch(err => console.log(err));

Comments

Popular posts from this blog

Service worker fetch all data

async css loading..

Javascript Prototype to Class