[英]Meteor method call returns undefined on the client but not on the server
我刚刚意识到这种方法存在根本性的错误,并且嵌套的回调不能向其父回调返回一些内容。 我在JS世界中来得很晚,来自Promises
时代,并不知道这是回调的问题。 但我没有看到Meteor使用promises的足够例子,所以我使用了回调。 但是,如果这个代码可以改进,我会非常感激。
所以我正在使用以下方法从客户端调用方法:
Meteor.call('cart.useProfileAddress', {}, (error, address) => {
console.info('Address', address) // this returns undefined on client
})
这是我的api/carts/cartsMethod.js
export const useProfileAddress = new ValidatedMethod({
name: 'cart.useProfileAddress',
validate(args) {
//
},
run(args) {
const person = Persons.findOne({'userId': Meteor.userId()});
// If I do the return here I get the address in the browser as defined.
// return person.address
// I'm calling another method under here:
getClosestStore.call({address: person.address}, (error, result) => {
// And another one method call here:
updateCartAddress.call({address: person.address}, (error, result) => {
// So once all the callbacks are done return the address here.
// However the problem is I get `undefined` on the client.
if (!error) {
// console displays something on the Server but is `undefined` on the Client
console.info('Returning Address', person.address)
return person.address
}
})
})
}
})
上面的代码可能有什么问题? 可能是因为我试图从嵌套回调中获取值吗?
也有人知道如何避免这些嵌套回调吗? 我知道如何使用promises在Node
进行,但在Meteor中(我使用的是1.4
)我仍然无能为力。
方法可以在服务器上同步运行,因此您不需要使用回调。 执行后将返回方法的结果,否则将在发生错误时抛出异常。 试试这个:
export const useProfileAddress = new ValidatedMethod({
// ...
run(args) {
const person = Persons.findOne({'userId': Meteor.userId()});
const result1 = getClosestStore.call({address: person.address});
// use result1 if you need to
const result2 = updateCartAddress.call({address: person.address});
// // use result2 if you need to
return person.address;
}
})
这就是我使用Promise和Meteor 1.3+
的新async/await
功能解决我的问题的方法
export const useProfileAddress = new ValidatedMethod({
name: 'cart.useProfileAddress',
validate(args) {
//
},
run(args) {
return ((async () => {
const person = Persons.findOne({'userId': Meteor.userId()});
const storeId = await getClosestStore.callPromise({address: person.address})
const newAddress = await updateCartAddress.callPromise({address: person.address})
return newAddress
})())
}
})
在每个方法中,我使用了didericis:callpromise-mixin,以便它返回一个promise。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.