-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpromise.js
More file actions
56 lines (53 loc) · 1.56 KB
/
Copy pathpromise.js
File metadata and controls
56 lines (53 loc) · 1.56 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
function httpGet(url) {
return new Promise((resolve, reject) => {
const request = new XMLHttpRequest();
request.addEventListener('readystatechange', () => {
if (request.readyState === XMLHttpRequest.DONE) {
if (request.status !== 200) {
reject(new Error('Failed to get data'));
return;
}
const data = JSON.parse(request.responseText);
resolve(data);
}
});
request.open('GET', url);
request.send();
});
}
function getUsers() {
return httpGet(`http://jsonplaceholder.typicode.com/users`);
}
function getPosts(userId) {
return httpGet(`https://jsonplaceholder.typicode.com/posts?userId=${userId}`);
}
getUsers()
.then((users) => {
let promises = users.map((user) => {
return getPosts(user.id)
.then((posts) => {
user.posts = posts;
return user;
});
});
return Promise.all(promises);
})
.then((users) => {
//render
const container = document.querySelector('#container');
const usersUl = document.createElement('ul');
container.appendChild(usersUl);
users.forEach((user) => {
const userLi = document.createElement('li');
userLi.innerText = user.name;
usersUl.appendChild(userLi);
const postsUl = document.createElement('ul');
userLi.appendChild(postsUl);
user.posts.forEach(post => {
const postLi = document.createElement('li');
postLi.innerText = post.title;
postsUl.appendChild(postLi);
});
});
})
.catch(err => console.error('failed to load', err));