-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript_promise.js
53 lines (48 loc) · 1.83 KB
/
script_promise.js
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
// version with Promise
const searchForm = document.querySelector('#search-form');
const movie = document.querySelector('#movies');
function apiSearch(event) {
event.preventDefault();
const searchText = document.querySelector('.form-control').value;
const server = 'https://api.themoviedb.org/3/search/multi?api_key=942cf276adefa306549de647ce5a6e18&language=ru&query=' + searchText;
movie.innerHTML = 'Загрузка';
requestApi(server)
.then(function (result) {
const output = JSON.parse(result);
let inner = '';
output.results.forEach(function (item) {
let nameItem = item.name || item.title;
let dateItem = item.first_air_date || item.release_date;
inner += '<div class="col-5">' + nameItem + '</div>';
inner += '<div class="alert alert-primary" role="alert"> Дата релиза: ' + dateItem + '</div>';
});
movie.innerHTML = inner;
console.log(output);
})
.catch(function(reason){
movie.innerHTML = 'Упс, что то пошо не так!';
console.log('error: ' + reason.status);
});
}
searchForm.addEventListener('submit', apiSearch);
function requestApi(url) {
return new Promise(function (resolve, reject) {
const request = new XMLHttpRequest();
request.open('GET', url);
request.addEventListener('load', function () {
if (request.status !== 200) {
reject({
status: request.status
});
return;
}
resolve(request.response);
});
request.addEventListener('error', function () {
reject({
status: request.status
});
});
request.send();
});
}