如何在d3.js中将数字标签远离x轴移动?

时间:2014-11-02 14:38:57

标签: javascript d3.js axis-labels

新手问题:如何从x轴进一步移动x轴刻度标签?下面的代码片段产生了这个:

current

而我想要的更像是这样:

desired

从这里的问题:

d3.js: Align text labels between ticks on the axis

似乎我需要使用select选择包含这些标签的文字,然后对其应用translate(0,-10)之类的内容,但我无法弄清楚这个文字的位置&#34生活" /执行这种选择的语法。对不起,如果这很简单;我是D3(和javascript)的新手。有人可以帮忙吗?提前致谢!代码如下。

<script>

var superscript = "⁰¹²³⁴⁵⁶⁷⁸⁹",
    formatPower = function(d) { return (d + "").split("").map(function(c) { return superscript[c]; }).join("");\
 };

var margin = {top: 20, right: 20, bottom: 100, left: 100},
    width = 400,
    height = 400;

var x = d3.scale.log()
    .domain([1e1, 1e4])
    .range([0, width])
    .nice();

var xAxis = d3.svg.axis()
    .scale(x)
    .orient("bottom")
    .tickValues([1e1, 1e2, 1e3, 1e4])
    .ticks(0, function(d) { return 10 + formatPower(Math.round(Math.log(d) / Math.LN10)); });

var svg = d3.select("body").append("svg")
    .attr("width", width + margin.left + margin.right)
    .attr("height", height + margin.top + margin.bottom)
  .append("g")
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")");

svg.append("g")
    .attr("class", "x axis")
    .attr("transform", "translate(0," + height + ")")
    .call(xAxis)
    .append("text")
    .attr("class", "label")
    .attr("x", (width+margin.left)/2)
    .attr("y", 60)
    .style("text-anchor", "end")
    .text("x-axis label");

</script>

1 个答案:

答案 0 :(得分:7)

使用tickPadding有一种更简单的方法。在您定义xAxis的位置,只需添加.tickPadding(15)(将15更改为您想要的像素数)。

此处示例:http://jsfiddle.net/henbox/5q4k2r0p/1/