加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Angularjs – Charts.js:相同的图表元素不会在其他视图上重画

发布时间:2020-12-17 07:45:28 所属栏目:安全 来源:网络整理
导读:我是新来的角色,试图创建我的第一个指令.我正在创建一个指令,将Charts.js2.0(beta)加载到我的应用程序中. 我有两个角度管理的视图,两个html视图都包含一个只包含图表元素的html页面. 问题是第一页正确绘制图表,当我转到其他视图时,图表div被加载,但图表不被
我是新来的角色,试图创建我的第一个指令.我正在创建一个指令,将Charts.js2.0(beta)加载到我的应用程序中.

我有两个角度管理的视图,两个html视图都包含一个只包含图表元素的html页面.

问题是第一页正确绘制图表,当我转到其他视图时,图表div被加载,但图表不被重新绘制.现在,如果我回到第一个查看它的空白.

链接到Plunker

我做错了什么?我的指令有什么问题吗?

提前致谢.

图表库中修改根范围上现有对象似乎存在问题,从而在以后忽略它.我不能真正追查这是做什么,但这是一个修复: http://plnkr.co/edit/jDQFV62FSeXAQJ6o7jE8

这是你有什么

scope.$watch('config',function(newVal) {
    if(angular.isDefined(newVal)) {
      if(charts) {
        charts.destroy();
      }
      var ctx = element[0].getContext("2d");
      charts = new Chart(ctx,scope.config);
      //scope.$emit('create',charts);
    }
  });

以上,您可以看到您正在将scope.config直接传递到图表方法中.这似乎是以某种方式修改数据,并且由于通过引用传递,您实际上正在修改$rootScope.sales.charts.如果您复制该对象并在本地使用它,如下所示,您没有这个问题.

这是我如何修复它.

scope.$watch('config',function(newVal) {
    var config = angular.copy(scope.config);
    if(angular.isDefined(newVal)) {
      if(charts) {
        charts.destroy();
      }
      var ctx = element[0].getContext("2d");
      charts = new Chart(ctx,config);
      //scope.$emit('create',charts);
    }
  });

您可以看到,而不是直接传递该对象,我们使用angular来创建一个副本(angular.copy()),这是我们传递的对象.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读