【发布时间】:2014-08-07 16:22:12
【问题描述】:
我正在尝试渲染一个 dc.js barChart,其中我的 y 轴是百分比 0-100%,我的 x 轴是数字,但是我想按日期对 x 轴进行排序。
我的数据如下所示:
date,trend,percent
01/01/2014 13:00,238,53.6
01/01/2014 13:15,239,64.2
01/01/2014 13:30,219,43.1
01/01/2014 13:45,219.2,43.1
01/01/2014 14:00,237.4,50.6
...
我正在将数据添加到交叉过滤器
data.forEach(function (d) { d.date = parseDate(d.date); });
var ndx = crossfilter(data);
var trendDimension = ndx.dimension(function (d) { return d.trend; });
var trendGroup = trendDimension.group().reduce(
function (p, v) {
p.time = v.date.getTime();
p.trend = +v.trend;
p.percent = +v.percent;
return p;
},
...
).order(function (p) { return p.time; }); // ??? order by time rather than trend
当我绘制维度和组时,我的 x 轴按趋势排序,因为我的 x 域看起来像:
var minTrend = trendDimension.bottom(1)[0].trend;
var maxTrend = trendDimension.top(1)[0].trend;
...
chart.x(d3.scale.linear().domain([minTrend, maxTrend]);
...
chart.render();
一切都在绘制,但条形图按趋势顺序排序,我希望它们按日期/时间顺序排序。
这可能吗?
编辑
我也试过了:
chart.ordering(function (d) { return d.value.time; });
但这似乎对排序没有影响......
【问题讨论】:
标签: javascript dc.js crossfilter