3

我已将 visjs 时间线包装成角度指令。当我调用$route.reload()外部控制器时,时间线消失了。页面重新加载完成后,指令仍然具有对原始时间线对象的引用,并且 dom 元素似乎没有改变。

有谁知道什么会导致它消失?

我创建了一个 plunkr,但我不知道如何在 plunker 中重新加载路由,因为这会改变 url。

http://plnkr.co/edit/hwShQ2iYR7TOcILSBcEY?p=preview

function timelineViewer() {

  var timeline;
  return {
    restrict: 'E',
    replace: true,
    scope: {
      data: '='
    },
    controller: function($scope) {
      var items = new vis.DataSet();
      var container = document.getElementById('vis-timeline');

      var options = {
        height: 100,
        width: 600,
        zoomMin: 1000 * 60 * 2,
        zoomMax: 1000 * 60 * 20
      };

      items.clear();
      items.add($scope.data);

      timeline = new vis.Timeline(container, items, options);

      console.log('Reloading directive ...')
    },
    template: '<div id="vis-timeline"></div>'
  };
}
4

1 回答 1

1

要重新加载路由需要为控制器设置路由,请参阅您的 plunker 的这个分支。它似乎与您实施的指令配合得很好,然后我不确定原因,后来我添加了一些期望解决问题的更改

解释plunker:

controller: function($scope, $element) {
  var items = new vis.DataSet();
  var container = $element[0];

angular 的指令已经引用了自身的 DOM 元素 ( $element),因此可以安全地使用它而不是让它通过document.getElementById

$scope.$on('$destroy', function () {
  console.log('Destroying directive ...')
  timeline.destroy();
});

此行确保在指令被销毁时销毁时间线,时间线具有destroy()清理受影响的 DOM 元素的方法

于 2015-07-12T17:26:47.820 回答