d3.js – 升级D3 Band从v3升级到v4

我正在尝试将 this fiddle更新为D3 v4

http://jsfiddle.net/AdamMills/Ljeh2etj/

这是原始缩放功能

bars.attr("transform","translate(" + d3.event.translate[0]+",0)scale(" + d3.event.scale + ",1)");
chart.select(".x.axis").attr("transform","+(height)+")")
    .call(xAxis.scale(x.rangeRoundBands([0,width * d3.event.scale],.1 * d3.event.scale)));
chart.select(".y.axis").call(yAxis);

我试图根据d3-zoom的文档更新它

bars.attr("transform",d3.event.transform);
chart.select(".x.axis").attr("transform",d3.event.transform)
    .call(xAxis.scale(d3.event.transform.rescaleX(x)));
chart.select(".y.axis").call(yAxis);

我在recaleX中遇到了一个未定义的错误
我错过了什么?

解决方法

您可以从小提琴中更改缩放功能的第二行:

chart.select(".x.axis")
                    .attr("transform","translate(" + d3.event.transform.x + "," + (height) + ")")
                        .call(
                             xAxis.scale(
                                 x.rangeRound([0,width * d3.event.transform.k])
                                     .paddingInner(.1 * d3.event.transform.k)));;

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...