最佳答案
给定您链接的示例,您唯一需要做的就是为每个SVG设置局部变量:
axis.set(this,d3.axisRight(ty).ticks(3));
在这里,我使用ticks(3)是因为那里没有太多垂直空间,而ty是为每个SVG创建的比例.然后,您以后可以将该局部变量用作:
svg.each(function(){
axis.get(this)(d3.select(this)
.append("g")
.attr("transform","translate(" + width + ",0)"));
});
这是更新的bl.ocks:https://bl.ocks.org/GerardoFurtado/7ce71db8470c75940feed0d64b3f1f25/fb38b0867f434268e254f08e469cf38113179472
PS:请注意以下事实:我在这里使用…
axisGenerator(groupSelection)
而不是更传统的方式
groupSelection.call(axisGenerator)
…因为我们无法用传统模式做到这一点.为了在没有每种方法的情况下使用传统模式,您需要一个奇怪的辅助函数,例如:
svg.append("g")
.attr("transform",0)")
.call(generateAxis);
function generateAxis(selection) {
selection.call(axis.get(selection.node()));
};