我有一些异步方法需要在从请求返回之前等待完成。我正在使用Promises,但我一直收到错误:
Each then() should return a value or throw // promise/always-return
为什么这样开心?这是我的代码:
router.get('/account', function(req, res) {
var id = req.user.uid
var myProfile = {}
var profilePromise = new Promise(function(resolve, reject) {
var userRef = firebase.db.collection('users').doc(id)
userRef.get()
.then(doc => { // Error occurs on this line
if (doc.exists) {
var profile = doc.data()
profile.id = doc.id
myProfile = profile
resolve()
} else {
reject(Error("Profile doesn't exist"))
}
})
.catch(error => {
reject(error)
})
})
// More promises further on, which I wait for
})
答案 0 :(得分:9)
避开Promise
constructor antipattern!如果您不打电话给{{ran}}
但是返回一个值,那么您将获得resolve
的内容。 return
方法应该用于chaining, not just subscribing:
then
答案 1 :(得分:2)
在firebase.db.collection('users').doc(id)
返回promise
本身的情况下,请检查firebase代码段为here以获取node-js。
如果您有多个承诺,并且需要逐个调用它们,请使用Promises chaining。
请检查此article这对您有帮助。
在您的案例中使用以下代码
router.get('/account', function(req, res) {
var id = req.user.uid;
var myProfile = {};
var userRef = firebase.db.collection('users').doc(id)
userRef.get()
.then(doc => {
if (!doc || !doc.exists) {
throw new Error("Profile doesn't exist")
}
var profile = doc.data();
profile.id = doc.id;
myProfile = profile;
return myProfile;
})
.catch(error => {
console.log('error', error);
})
})
如果您有多个承诺并且您希望一次执行它们,请使用Promise.all。
Promise.all(iterable)
方法返回一个Promise,它在iterable参数中的所有promise已经解析或者iterable参数不包含promise时解析。它拒绝承认拒绝的第一个承诺。
例如:
var promise1 = new Promise((resolve, reject) => {
setTimeout(resolve, 100, 'foo1');
});
var promise2 = new Promise((resolve, reject) => {
setTimeout(resolve, 100, 'foo2');
});
var promise3 = new Promise((resolve, reject) => {
setTimeout(resolve, 100, 'foo3');
});
Promise.all([promise1, promise2, promise3])
.then(result => console.log(result))
//result [foo1, foo2, foo3]
希望这会对你有所帮助!!
答案 2 :(得分:1)
答案 3 :(得分:0)
如果您无法解决此问题,但仍想运行您的代码...
open : eslintrc.json file (search from project root directory)
search : 'promise/always-return'
change : Case 1: if (existing value is 2) => change to 1
Case 2: else if(existing value is "error" => change to "warn")
这将使该错误成为警告,但请务必谨慎...还应在编辑器中使用eslint plungin来提醒良好做法。否则,您将不会收到任何与承诺/总是返回有关的警告。
如果您的搜索中出现多个eslintrc.json,还请确保找到正确的