У меня есть 2 функции. Я использую метод then() для promise. Но я пытаюсь запустить функцию second после первого обещания. Но теперь второй вызов функции как первый. как это исправить?
или возникла проблема с моим кодом?
вот моя попытка:
var getData = function(){
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(42); //consoles as second
}, 5000);
})
}
var getDataMoreData = function(){
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(43); //consoles as first
}, 3000);
})
}
getData().then((data)=> console.info('Data', data)).then(getDataMoreData().then((data)=> console.info('data--', data )));



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


.then принимает функция в качестве параметра. Когда ты делаешь
.then(getDataMoreData()
.then((data) => console.info('data--', data))
);
, он немедленно вызывает getDataMoreData() (с ожиданием, что он вернет функцию, которую можно поместить в цепочку обещаний). Но getDataMoreData не возвращает функцию - он возвращает обещание.
Любая функция звонки непосредственно внутри then выполняется немедленно, поскольку она пытается построить цепочку обещаний .then. Просто укажите переменную функции внутри then вместо ее вызова:
var getData = function() {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(42);
}, 500);
})
}
var getDataMoreData = function() {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(43);
}, 300);
})
}
getData()
.then((data) => console.info('Data', data))
.then(getDataMoreData)
.then((data) => console.info('data--', data));
этот ответ правильный - в качестве примечания, если вам не нужно последовательное выполнение, вы можете запустить их параллельно с: Promise.all ([getData (), getMoreData ()]. then ((data1, data2) => {})