gpt4 book ai didi

javascript - 在水平条形图上的条形后附加文本

转载 作者:行者123 更新时间:2023-11-30 14:04:20 24 4
gpt4 key购买 nike

我正在绘制水平条形图,我想将 y 标签移动到条形之后。

d3.csv("mydata.csv", function(data) {

// Add X axis
var x = d3.scaleLinear()
.domain([0, 100])
.range([ 0, width])

svg.append("g")
.attr("transform", "translate(0,0)")
.call(d3.axisTop(x).ticks(10).tickFormat(function(d){return d+ "%"}))
.selectAll("text")
.attr("transform", "translate(10,-12)rotate(-45)")
.style("text-anchor", "end");

// Y axis
var y = d3.scaleBand()
.range([ 0, height ])
.domain(data.map(function(d) { return d.type; }))
.padding(.5);

svg.append("g")
.call(d3.axisRight(y))
.selectAll('text')
.attr("x", function(d) { return d.number; } )

//Bars
svg.selectAll("myRect")
.data(data)
.enter()
.append("rect")
.attr("x", x(0.5) )
.attr("y", function(d) { return y(d.type); })
.attr("width", function(d) { return x(d.number); })
.attr("height", y.bandwidth() )
.attr("fill", "#69b3a2")

})

CSV 文件有两列

  • 输入
  • 人数

关于这部分代码

  svg.append("g")
.call(d3.axisRight(y))
.selectAll('text')
.attr("x", function(d) { return d.number; } )

如果我将行 .attr("x", function(d) { return d.number; } ) 替换为.attr("x", 100 ) 然后它将标签向右移动。但是当我尝试通过条的宽度保持动态时,文本保持在 y 轴的起点。

最佳答案

在您的代码中,而不是创建一个带有标签的新选择 <text>元素,你正试图移动轴的刻度!这是一种非常不常见的方法,但它确实可行。

主要问题只是数据:在这一行...

.attr("x", function(d) { return d.number; })

...数据 ( d ) 与矩形所具有的数据不同,它来自您的数据。这里的数据只是轴刻度中的字符串。

因此,我们必须得到真正的数据,这样我们才能得到number值(value)。像这样:

.attr("x", function(d) {
const datum = data.find(function(e){return e.type === d})
return x(datum.number);
})

这是您的代码(以及一些虚假数据):

var width = 500,
height = 300,
padding = 20;

var data = [{
type: "foo",
number: 42
},
{
type: "bar",
number: 12
},
{
type: "baz",
number: 79
},
{
type: "foobar",
number: 17
},
{
type: "foobaz",
number: 36
}
];

var svg = d3.select("body")
.append("svg")
.attr("width", width)
.attr("height", height);

var x = d3.scaleLinear()
.domain([0, 100])
.range([padding, width - padding])

svg.append("g")
.attr("transform", "translate(0,20)")
.call(d3.axisTop(x).ticks(10).tickFormat(function(d) {
return d + "%"
}))
.selectAll("text")
.attr("transform", "translate(10,-12)rotate(-45)")
.style("text-anchor", "end");

// Y axis
var y = d3.scaleBand()
.range([padding, height - padding])
.domain(data.map(function(d) {
return d.type;
}))
.padding(0.5);

svg.append("g")
.attr("transform", "translate(20,0)")
.call(d3.axisRight(y))
.selectAll('text')
.attr("x", function(d) {
const datum = data.find(function(e) {
return e.type === d
})
return x(datum.number) + 6;
})

//Bars
svg.selectAll("myRect")
.data(data)
.enter()
.append("rect")
.attr("x", x(0.5))
.attr("y", function(d) {
return y(d.type);
})
.attr("width", function(d) {
return x(d.number);
})
.attr("height", y.bandwidth())
.attr("fill", "#69b3a2")
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"></script>

关于javascript - 在水平条形图上的条形后附加文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55726213/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com