0
我有條形圖,我想更新數據和座標值。到目前爲止,我只是成功地刪除了欄,但我無法刪除x軸和y軸的標籤。我用svg.selectAll(「.bar」)。remove(); ,但它只刪除了條,並留下了x軸和y軸。更新條形圖和刪除標籤
如何刪除軸的標籤?
d3.tsv("data.tsv", type, function (error, data) {
if (error) throw error;
x.domain(data.map(function (d) {
return d.letter;
}));
y.domain([0, d3.max(data, function (d) {
return d.frequency;
})]);
svg.append("g")
.attr("class", "x axis")
.attr("transform", "translate(0," + height + ")")
.call(xAxis);
svg.append("g")
.attr("class", "y axis")
.call(yAxis)
.append("text")
.attr("transform", "rotate(-90)")
.attr("y", 6)
.attr("dy", ".71em")
.style("text-anchor", "end")
.text("Frequency");
svg.selectAll(".bar")
.data(data)
.enter().append("rect")
.attr("class", "bar")
.attr("x", function (d) {
return x(d.letter);
})
.attr("width", x.rangeBand())
.attr("y", function (d) {
return y(d.frequency);
})
.attr("height", function (d) {
return height - y(d.frequency);
});
});
function updateData(input) {
svg.selectAll(".bar").remove();}
感謝您的幫助,但它沒有工作,標籤仍然存在,即使是舊數據中的幾個條仍然存在。如果你想嘗試自己,那麼完整的代碼就在這裏。 https://bl.ocks.org/mbostock/3885304 –
輸入你的新數據嗎?如果是,只需寫入'.data(input'。'Selection()。exit()'將新數據綁定到所選內容,並選擇所有元素而不包含新數據 –
但是,如果要刪除所有條相應的軸標籤,只是讓你的'data'成爲一個空數組。 –