繁体   English   中英

在 DC.js 图表中缩放 y-tick 标签(下面是 D3.js)

[英]Scale y-tick labels in DC.js chart (D3.js underneath)

我正在尝试找到一种方法来动态缩放图表的 y 轴,以便这些值以个位数显示,顶部带有指数表示,有效地改变了这一点:
未缩放的 y 轴

对此:

缩放 y 轴

请注意,这在例如 Matlab/Matplotlib/等中自动工作,但我正在努力寻找 web 绘图框架的解决方案(也许我的搜索语言是错误的)......我知道 D3.js 不是图表库,但我会接受与前端 DC.js 或后端 D3.js 一起使用的解决方案


根据下面@Gordon 的回答进行编辑,我使用它得到下图

chart.yAxis().tickFormat(d3.format('.1e'));

指数格式

是否有可能将所有 e+6 移到顶部? 还是我需要自己编写一个自定义缩放 function 并插入一个单独的文本框?

在 dc.js 中,轴直接来自d3-axis

使用chart.xAxis()chart.yAxis()访问它们,为了减少混淆,请在图表初始化的 rest 的单独语句中执行此操作。

您可以使用axis.tickFormat来控制刻度文本的格式。

您可以使用d3.format进行自动格式化。 似乎指数或 SI 表示法可能适合您正在做的事情,尽管它与在屏幕截图中的单独文本元素中使用指数并不完全相同。

放在一起,这很接近

chart.yAxis().tickFormat(d3.format('.1e'))

刻度格式问题出现了很多。 我想知道我们可以把这些信息放在哪里,这样人们就不必问了。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM