解决方案
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。实践出真知,还真可以,而且缩放功能也正常使用,完美解决!
运行结果

文章讲述了在使用D3.js最新版本7.8.2绘制树形图时遇到的问题,即在`zoomFn`函数中调用`d3.event.transform`导致的TypeError。作者发现`d3.event`在v7中已被移除,通过查阅资料并自我探索,找到了替代方案,即直接使用参数中的`transform`属性,成功实现了缩放功能并解决了问题。
772

被折叠的 条评论
为什么被折叠?



