我想从存储到数据库中的列表中填充内存中的受限单词列表,因为希望是动态的。听起来很简单吧?不,不是!为什么 ?
这是它的简短代码:
if (Meteor.isServer) {
Meteor.startup(function() {
var configCollection = new Mongo.Collection('config');
// An wrapper object for easy referencing
var words = {
faulty: ['f_word_here']
}; // Some default faulty words
var updateFaultyWords = function() {
var config = configCollection.findOne();
if (config) {
words.faulty = config.faultyWords;
}
};
// ------- Problematic Code ------
Tracker.autorun(function() {
updateFaultyWords();
});
// -------------------------------
// later somewhere in the code
var allowWord = function(word) {
return words.faulty.indexOf(word) === -1;
};
});
}
我在这里使用 Tracker,因为就像文档中所说的那样,我想以反应模式更新我的列表。
Tracker.autorun 允许您运行依赖于响应式数据源的函数。每当使用新数据更新这些数据源时,该函数将重新运行。
但是,此方法会因我无法理解的堆栈跟踪而大量崩溃:
W20151209-17:36:55.802(1)? (STDERR)
W20151209-17:36:55.802(1)? (STDERR) /Users/tiberiu/.meteor/packages/meteor-tool/.1.1.10.1b51q9m++os.osx.x86_64+web.browser+web.cordova/mt-os.osx.x86_64/dev_bundle/server-lib/node_modules/fibers/future.js:245
W20151209-17:36:55.802(1)? (STDERR) throw(ex);
W20151209-17:36:55.803(1)? (STDERR) ^
W20151209-17:36:55.865(1)? (STDERR) Error: Can't call yield in a noYieldsAllowed block!
W20151209-17:36:55.865(1)? (STDERR) at Function.Fiber.yield (packages/meteor/fiber_helpers.js:8:1)
W20151209-17:36:55.865(1)? (STDERR) at Function.wait (/Users/tiberiu/.meteor/packages/meteor-tool/.1.1.10.1b51q9m++os.osx.x86_64+web.browser+web.cordova/mt-os.osx.x86_64/dev_bundle/server-lib/node_modules/fibers/future.js:183:14)
W20151209-17:36:55.865(1)? (STDERR) at Object.Future.wait (/Users/tiberiu/.meteor/packages/meteor-tool/.1.1.10.1b51q9m++os.osx.x86_64+web.browser+web.cordova/mt-os.osx.x86_64/dev_bundle/server-lib/node_modules/fibers/future.js:397:10)
W20151209-17:36:55.865(1)? (STDERR) at [object Object]._.extend._nextObject (packages/mongo/mongo_driver.js:986:1)
W20151209-17:36:55.865(1)? (STDERR) at [object Object]._.extend.forEach (packages/mongo/mongo_driver.js:1020:1)
W20151209-17:36:55.866(1)? (STDERR) at [object Object]._.extend.map (packages/mongo/mongo_driver.js:1030:1)
W20151209-17:36:55.866(1)? (STDERR) at [object Object]._.extend.fetch (packages/mongo/mongo_driver.js:1054:1)
W20151209-17:36:55.866(1)? (STDERR) at [object Object].Cursor.(anonymous function) [as fetch] (packages/mongo/mongo_driver.js:869:1)
W20151209-17:36:55.866(1)? (STDERR) at [object Object].MongoConnection.findOne (packages/mongo/mongo_driver.js:776:1)
W20151209-17:36:55.867(1)? (STDERR) at [object Object]._.extend.findOne (packages/mongo/collection.js:305:1)
我究竟做错了什么 ?我应该将此报告为错误吗?