d3.event.transform不能用了

解决方案

const zoom = d3.zoom().scaleExtent(this.scaleRange).on('zoom', this.zoomFn);


      //初始化缩放方法
      zoomFn(svg, a, b, c) {
      // 低版本方法
        // const zoom = d3.event.transform;
        // return this.container.attr('transform', svg.transform);
        
// 新版本方法
return this.container.attr('transform', svg.transform);
      },

最近参考一个别人使用的d3js代码,画树形图的,自己重新下载的d3, 使用的最新版本7.8.2。

问题

但是代码拉取下拉之后没法运行:App.vue:179 Uncaught TypeError: Cannot read properties of undefined (reading 'transform'),

查资料

查了下资料,d3.event在v7版本已经没有了。
然后开始自己的搜索之路........然而,貌似,好像有人也遇到这个问题,但是呢,我的问题依旧在。然后开始自己探索...

Debug

既然这里的参数已经带了transform, 就尝试一下此transform是否为彼transform。实践出真知,还真可以,而且缩放功能也正常使用,完美解决!

运行结果

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值