【发布时间】:2013-09-09 19:40:11
【问题描述】:
是否有可能从 Meteor 的 observe 回调中调用服务器方法?
我整理了一个重现该问题的示例,即从 myCursor.observe() 的回调中调用的 Meteor.call() 不会执行。当从观察回调中调用时,Meteor.method 本身也不会出现错误回调,它只是返回 Undefined。
不要理我,Meteor.call() :) 非常感谢任何帮助!
observe.js
items=new Meteor.Collection("Items");
if (Meteor.isClient) {
Meteor.subscribe("Items");
Meteor.startup(function(){
itemsCursor=items.find();
itemsHandle=itemsCursor.observe({
added : function(doc){
console.log("added "+doc.text);
Meteor.call('aMethod',doc.text,function(e,r){
if(e){
console.log("error from server: "+e);
}else{
console.log("response from server: "+r);
}
});
},
removed : function(doc){
console.log("removed "+doc.text);
Meteor.call('aMethod',doc.text,function(e,r){
if(e){
console.log("error from server: "+e);
}else{
console.log("response from server: "+r);
}
});
}
});
});
Template.test.items=function(){
return items.find();
}
Template.test.events({
'click #add':function(){
items.insert({"text":"Timestamp: "+(new Date().getTime())});
},
'click #remove':function(){
items.remove(items.findOne()._id);
}
});
}
if (Meteor.isServer) {
Meteor.publish("Items",function(){
return items.find();
});
items.allow({
insert : function(userId,doc){
return true;
},
update : function(userId,doc){
return true;
},
remove : function(userId,doc){
return true;
}
});
Meteor.methods({
aMethod:function(text){
console.log("Got it! "+text);
return "Got it! "+text;
}
});
}
observe.html
<head>
<title>observe</title>
</head>
<body>
{{> test}}
</body>
<template name="test">
<button id="add">add item</button>
<button id="remove">remove item</button>
<ol>
{{#each items}}
<li>{{text}}</li>
{{/each}}
</ol>
</template>
【问题讨论】:
标签: javascript mongodb collections meteor