我只开始学习d3.js +线条图与传说&工具提示。而且我能够使其工作,但我想要的是将yAxis结果以百分比格式。尝试使用tickFormat,但不知何故,它不会将我的原始数字转换为百分比。 T__T将结果转换为d3中的百分比
这里是我的js代码
chart = d3LineWithLegend()
.xAxis.label('Date')
.width(700)
.height(300)
.yAxis.label('Frequency');
var svg = d3.select('#histogram svg').datum(data);
svg.transition().duration(1000)
.attr('width', 700)
.attr('height', 300)
.call(chart);
chart.dispatch.on('showTooltip', function(e) {
var offset = $('#histogram').offset(), // { left: 0, top: 0 }
left = e.pos[0] + offset.left,
top = e.pos[1] + offset.top,
// formatter = d3.format(".04f");
formatter = d3.format(".0%");
var yAxis = d3.svg.axis().orient("left").tickFormat(formatter);//added this part but it didn't work
console.log(yAxis);
var dateObj = (new Date(e.point[0]));
var year = dateObj.getFullYear();
var month = dateObj.getMonth() + 1;
var day = dateObj.getDate();
var hours = dateObj.getHours();
var date = month + '-' + day + '-' + year;
if(filter === 'hour') {
date = date + ', ' + hours + ':00';
}
var content = '<h3>' + date + '</h3>' +
'<p>' +
'<span class="value">' + (e.point[1]) + '</span>' +
'</p>';
nvtooltip.show([left, top], content);
});
chart.dispatch.on('hideTooltip', function(e) {
nvtooltip.cleanup();
});
似乎什么在我上面的代码中的问题?如果我不在客户端工作,我正考虑在服务器端进行调整。但太多的工作。
您不使用您在任何地方定义的'yAxis'。你需要把它给图形规范。 'd3LineWithLegend()'来自哪里? – 2013-05-03 09:06:23