gpt4 book ai didi

javascript - D3.js 从 json 更新条形图

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:49:48 24 4
gpt4 key购买 nike

我正在使用 d3.js 制作条形图,条形应该能够对应于新的 json 数据。

var m = [30, 5, 5, 5],
w = 375 - m[1] - m[3],
h = 260 - m[0] - m[2];

var format = d3.format(",.0f");

var wdthnew = d3.scale.linear().range([0, w]),
wdth = d3.scale.linear().range([0, w]).domain([0, 25000]),
hght = d3.scale.ordinal().rangeRoundBands([0, h], .1);

var svg = d3.select("body").append("svg")
.attr("width", w + m[1] + m[3])
.attr("height", h + m[0] + m[2])
.append("g")
.attr("transform", "translate(" + m[3] + "," + m[0] + ")");

d3.json("barchartjson.php", function(data) {

data.sort(function(a, b) { return b.value - a.value; });
hght.domain(data.map(function(d) { return d.orientation; }));

var bar = svg.selectAll("g.bar")
.data(data)
.enter().append("g")
.attr("class", "bar")
.attr("transform", function(d) { return "translate(0," + hght(d.orientation) + ")"; });

bar.append("rect")
.attr("id", "activebar")
.attr("width", 0)
.attr("height", hght.rangeBand())
.transition()
.delay(100)
.duration(1000)
.attr("width", function(d) { return wdth(d.value); });
});

function makebar(date1, date2) {
var barchartjson = "barchartjson.php?df="+date1+"&dl="+date2;

d3.json(barchartjson , function(datanew) {

datanew.sort(function(a, b) { return b.jumlah - a.jumlah; });

wdthnew.domain([0, d3.sum(datanew, function(d) { return d.value; })]);

console.log("SUM datanew: "+ d3.sum(datanew, function(d) { return d.value; }));
console.log("Array datanew: ");
console.log(datanew);
var updatebar = svg.selectAll("#activebar");

updatebar.transition().duration(1000)
.attr("width", function(a) { console.log("update width: wdthnew("+a.value+") = "+wdthnew(a.value));
return wdthnew(a.value); });
});
}

这是第一次使用的barchartjson.php中的json:

[{"orientation":"negatif","value":"15964"},{"orientation":"netral","value":"2788"},{"orientation":"positif","value":"9701"}]

条形图第一次正确显示。 问题是在调用 makebar() 时,使用新的 json 数据更新条形宽度。每个条形宽度都会更新,但在某些情况下它们会超出范围。这是 console.log 的输出:

SUM datanew: 2520
Array datanew:
[Object
value: "1411"
orientation: "negatif"
__proto__: Object
,
Object
value: "846"
orientation: "positif"
__proto__: Object
,
Object
value: "263"
orientation: "netral"
__proto__: Object
]
update width: wdthnew(15964) = 2312.246031746032
update width: wdthnew(9701) = 1405.1051587301588
update width: wdthnew(2788) = 403.81746031746036

成功调用了一个新的 json,但是日志显示 wdthnew 一直在缩放旧的 json。

 updatebar.transition().duration(1000)
.attr("width", function(a) { console.log("update width: wdthnew("+a.value+") = "+wdthnew(a.value));
return wdthnew(a.value); });

结果:

update width: wdthnew(15964) = 2312.246031746032

尽管 15694 来自旧的 json,wdthnew(d.value) 实际上是从 wdthnew(1411) 返回一个值,它是 2312 并且超出范围..

有人可以帮我解决这个问题吗?或者指出我哪里做错了?我是 d3.js 和 javascript 的新手。我很抱歉语法不好。英语不是我的母语。

jsFiddle 在这里:http://jsfiddle.net/saido/5mREA/

最佳答案

原来问题出在 function makebar():在这一行我应该附上新数据:

var updatebar = svg.selectAll("#activebar").data(datanew);

现在 console.log 显示并计算正确的值。

很抱歉,我不确定如何更详细地解释技术问题。

关于javascript - D3.js 从 json 更新条形图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10314630/

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