onRendered触发Tracker afterFlush的异常 - 函数ReferenceError:未定义dragula

时间:2016-04-03 01:46:48

标签: meteor iron-router

我无法使用ahref:dragula包正确导入dragula。它工作得很好,直到我手动刷新浏览器页面。当我这样做时,我收到以下错误:

debug.js:41 Exception from Tracker afterFlush function:
debug.js:41 ReferenceError: dragula is not defined
    at .<anonymous> (tasks.js:52)
    at blaze.js:3302
    at Function.Template._withTemplateInstanceFunc (blaze.js:3643)
    at fireCallbacks (blaze.js:3298)
    at .<anonymous> (blaze.js:3391)
    at blaze.js:1752
    at Object.Blaze._withCurrentView (blaze.js:2183)
    at blaze.js:1751
    at Object.Tracker._runFlush (tracker.js:505)
    at onGlobalMessage (setimmediate.js:102) 

阅读时,我偶然发现了这个question/answer,这让我觉得这条路线可能需要某种waitOn,我只是不知道到底应该等些什么。以下是我为清除可读性而编写的一些代码,希望我没有删除任何重要信息。所以,这是我的路线定义目前的样子。

Router.route('/', function () {
  this.render('Home');
});

模板......

<template name="home">
  {{ #if currentUser }}
    {{> tasks }}
  {{ /if }}
</template>

<template name="tasks">
    <div class="row">
      <div id="activeTasks">
        <!-- stuff -->
      </div>
    </div>
  </div>
</template>

最后,onRendered函数本身。

Template.tasks.onRendered(function() {
  this.drake = dragula([this.find('#activeTasks')]);
});

1 个答案:

答案 0 :(得分:0)

基于this discussion,我找到了一个解决方法,包括在Meteor.setTimeout函数中使用dragula定义进行换行。

生成的onRendered函数:

Template.tasks.onRendered(function() {
  var self = this;
  Meteor.setTimeout(function() {
    self.drake = dragula([self.find('#activeTasks')]);
  }, 250);
});