05.03.2024, 21:24
|
|
Кандидат Javascript-наук
|
|
Регистрация: 07.12.2012
Сообщений: 147
|
|
Можно ли здесь использовать then?
Здравствуйте!
Делаю тестовое задание, в котором надо выводить товары, возвращаемые с рандомной удачей локальным сервером (в папке server). В импортируемой модели(файл APImodel.js в папке client) создал метод getGoodsList:
function getGoodsList(step = 0) {
fetch(`http://localhost:3000/api/products?status=200`)
.then(res => {
if (res.status === 404) {
return {}
}
if (res.status === 500) {
if (step < 2) {
getGoodsList(step++);
}
else {
createMessage('Произошла ошибка, попробуйте обновить страницу позже');
}
}
return res.json();
})
.then (json => {
if (!(!json.products || json.products.length === 0)) return json;
})
.catch(error => {
console.log(`Error name is: ${error.name}, error message is: ${error.message}`);
});
}
который в файле view.js вызываю таким образом:
async function createApp(container, model) {
//showSpiner();
model.getGoodsList()
.then(goodsData => {
if (goodsData !== null && goodsData.products.length > 0){
let goodsUL = createGoodsList();
container.append(goodsUL);
for (let item in goodsData.products) {
let product = createLi(goodsData.products[item]);
goodsUL.append(product);
}
}
});
}
Можно ли здесь использовать .then? Или это только для promise объектов, и мой метод getGoodsList возвращает не promise?
|
|
05.03.2024, 21:40
|
Профессор
|
|
Регистрация: 04.12.2012
Сообщений: 3,791
|
|
Сообщение от borus
|
Можно ли здесь использовать .then?
|
Нет, нельзя. Ваша функция `getGoodsList`, возвращает undefined, а у undefined нет метода then.
Сообщение от borus
|
возвращаемые с рандомной удачей локальным сервером
|
Что значит "с рандомной удачей"? Когда-то вернет, когда-то закрашится?
Код, конечно, "мое почтение". Хотел про логику обработки ответа от сервера написать, а потом дальше посмотрел и понял, что смысла особого нет, у вас все плохо.
|
|
05.03.2024, 21:47
|
|
Кандидат Javascript-наук
|
|
Регистрация: 07.12.2012
Сообщений: 147
|
|
Спасибо. А почему она возвращает undefined?
Да, создателями сервера запрограммирован случайный ответ
|
|
05.03.2024, 22:16
|
|
Профессор
|
|
Регистрация: 25.10.2016
Сообщений: 1,012
|
|
Сообщение от borus
|
А почему она возвращает undefined?
|
ты забыл return
|
|
06.03.2024, 13:54
|
|
Кандидат Javascript-наук
|
|
Регистрация: 07.12.2012
Сообщений: 147
|
|
Сообщение от Alexandroppolus
|
ты забыл return
|
Так в первом посте видно, что в 18 строке определения функции getGoodsList() есть return json; в последнем then(). Не катит?
|
|
06.03.2024, 14:09
|
Профессор
|
|
Регистрация: 04.12.2012
Сообщений: 3,791
|
|
borus, а почему вы считаете, что функция getGoodsList должна вернуть вам результат строки 18, а не 15 например?
Строки 15 и 18 возвращают результат работы именно тех стрелочных функций, в которых они написаны. Сама же функция getGoodsList у вас не имеет ключевого слова return и, соответственно, не возвращает ничего или, можно сказать, возвращает undefined.
Строка 18 возвращает данные, которые будут храниться в промисе (Promise), который возвращает функция fetch.
Последний раз редактировалось Nexus, 06.03.2024 в 14:11.
|
|
06.03.2024, 14:30
|
|
Кандидат Javascript-наук
|
|
Регистрация: 07.12.2012
Сообщений: 147
|
|
Сообщение от Nexus
|
borus, а почему вы считаете, что функция getGoodsList должна вернуть вам результат строки 18, а не 15 например?
|
потому что возвращаться должен результат последнего then, насколько понимаю.
Получается функцию getGoodsList() правильнее написать так:
function getGoodsList(step = 0) {
return fetch(`http://localhost:3000/api/products?status=200`)
.then(res => {
if (res.status === 404) {
return {}
}
if (res.status === 500) {
if (step < 2) {
getGoodsList(step++);
}
else {
createMessage('Произошла ошибка, попробуйте обновить страницу позже');
}
}
return res.json();
})
.then (json => {
if (!(!json.products || json.products.length === 0)) return json;
})
.catch(error => {
console.log(`Error name is: ${error.name}, error message is: ${error.message}`);
});
}
?
|
|
06.03.2024, 17:11
|
Профессор
|
|
Регистрация: 04.12.2012
Сообщений: 3,791
|
|
Сообщение от borus
|
Получается функцию getGoodsList() правильнее написать так:
|
Да, в таком случае ваша функция будет возвращать промис, который будет содержать полученные от сервера данные или undefined.
И, btw, у вас в файле view.js в 5й строчке будет ошибка:
if (goodsData !== null && goodsData.products.length > 0){
У вас в переменной `goodsData` может быть как объект, так и undefined, о чем выше уже писал. Вы же проверяете является ли goodsData строго null'ом или нет (всегда будет true, поскольку {} !== null и undefined !== null).
Если `goodsData` содержит undefined, то проверка на не null пройдет успешно, а дальше вы попытаетесь прочитать свойство `products` у undefined, что закономерно вызовет ошибку: «cannot read property 'products' on undefined»
А в 9й строчке кода сообщения #7 запрос к серверу будут осуществлен "в холостую", т.к. результаты этого запроса просто игнорируются.
Последний раз редактировалось Nexus, 06.03.2024 в 17:13.
|
|
07.03.2024, 18:34
|
|
Кандидат Javascript-наук
|
|
Регистрация: 07.12.2012
Сообщений: 147
|
|
Сообщение от Nexus
|
А в 9й строчке кода сообщения #7 запрос к серверу будут осуществлен "в холостую", т.к. результаты этого запроса просто игнорируются.
|
Здравствуйте! Спасибо.
Как это игнорируются? Если в результатах res.status === 500, то только тогда делается повторная попытка запроса данных с сервера.
|
|
07.03.2024, 19:10
|
|
Профессор
|
|
Регистрация: 03.02.2020
Сообщений: 2,745
|
|
Но повторная попытка ничего не возвращает.
getGoodsList должен вернуть промис.
При вызове второй раз ничего не возвращается. Что тогда должен вернуть первый getGoodsList?
|
|
|
|