Tash1moto
@Tash1moto

Как лучше изменить код?

Что с этим можно сделать? либо синхронно сделать либо подождать как то?
либо как-то объеденить запросы в один
let categories,products,seasons,sizes
    categoryModel.find({}).then(a=>{
      categories=a
      productModel.find({}).then(b=>{
        products=b
        seasonModel.find({}).then(c=>{
          seasons=c
          sizeModel.find({}).then(d=>{
            sizes=d
            res.render("admin",{categories,products,seasons,sizes})
          })
        })
      })
    })
  • Вопрос задан
  • 220 просмотров
Решения вопроса 3
Примерно вот так:
const queries = [
    categoryModel.find({}),
    productModel.find({}),
    seasonModel.find({}),
    sizeModel.find({})
];
Promise.all(queries).then(result => {
    console.log(result);
}).catch(err => {
    throw err;
});
Ответ написан
Комментировать
@Interface
Если запросы независимы, можно, например, так:
// имитирует ассинхронный запрос
function find(val){
    return new Promise(resolve => setTimeout(
        () => resolve(val),
        Math.round(Math.random() * 5000)
    ));
};

// main - функция для примера, вставляйте код в свою ассинхронную функцию
async function main() {
    const [categories, products, seasons, sizes] = await Promise.all([
        find('categories'),
        find('products'),
        find('seasons'),
        find('sizes')
    ]);

    console.log(categories, products, seasons, sizes);
}

main()
Ответ написан
Комментировать
@Coder321
async (req, res) => {
    try {
        const categories = await categoryModel.find({});
        const products = await productModel.find({});
        const seasons = await seasonModel.find({});
        const sizes = await sizeModel.find({});
        return res.render("admin", { categories, products, seasons, sizes });
    } catch (error) {
        console.log(error);
        return res.render('error');
    };
}

async (req, res) => {
    try {
        const [categories, products, seasons, sizes] = await Promise.all([
            categoryModel.find({}),
            productModel.find({}),
            seasonModel.find({}),
            sizeModel.find({})
        ])
        return res.render("admin", { categories, products, seasons, sizes });
    } catch (error) {
        console.log(error);
        return res.render('error');
    };
}
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы