我有这样的代码使Express.js日志错误:如何在异步操作
exports.listSavedThreads = function (req, res) {
SavedThread.find({}).exec().then(function (data) {
wat.map();
res.render('home/listSavedThreads');
});
};
wat
是不确定的变量,因此上面的代码不工作,res.render()
不会被调用,但什么都没有打印到控制台,它无声无息地失败,浏览器陷入无尽的负载。
如果我做同样的未经许:正在打印到控制台和浏览器
exports.listSavedThreads = function (req, res) {
wat.map();
res.render('home/listSavedThreads');
};
误差,像往常一样。
我已经能够打印错误的唯一方法是通过使用try/catch
:
exports.listSavedThreads = function (req, res) {
SavedThread.find({}).exec().then(function (data) {
try {
wat.map();
res.render('home/listSavedThreads');
} catch(e) {
console.log('Error: ', e);
}
});
};
然后在控制台中我看到:
Error: [ReferenceError: wat is not defined]
很显然,我不能将try/catch
放到每个操作中,因为我大多需要用于开发的错误输出,所以我可以看到我的拼写错误和类似的东西。有没有办法输出所有操作的错误,甚至是异步的?
您正在正确使用try/catch。如果你的设计需要你一遍又一遍地写相同的代码,你可能会考虑一个功能分解或者如果你挖掘OO,使用多态可能也会清理它。 –
@NathanielJohnson,在我写的每一个异步函数中放入'try/catch'都会带来一点负担,如果我需要的只是错误日志。浏览器在承诺内打印错误就好,为什么Node不能?我认为,我的配置可能有问题,但我不确定在哪里寻找。 –