4
내 초기 막 대형 차트를 성공적으로 빌드했습니다. 이제 전환 효과를 사용하여 기존 차트에 막대를 추가하여 멋진 사용자 경험을 얻고 자합니다.D3 : 기존 막 대형 차트의 데이터를 변경하는 방법
여기 내 코드입니다 :
var data = [23, 85, 67, 38, 70]; //dummy, normally much more
labellist = ['label1','label2','label3','label4','label5'];
var w = 815,
h = 500,
labelpad = 165,
x = d3.scale.linear().domain([0, 100]).range([0, w]),
y = d3.scale.ordinal().domain(d3.range(data.length)).rangeBands([0, h], .2);
mySvg = d3.select("#chart")
.append("svg");
vis = mySvg.attr("width", w + 40)
.attr("height", h + 20)
.append("svg:g")
.attr("transform", "translate(20,0)");
bars = vis.selectAll("g.bar")
.data(data)
.enter().append("svg:g")
.attr("class", "bar")
.attr("transform", function(d, i) { return "translate(" + labelpad + "," + y(i) + ")"; })
bars.append("svg:rect")
.transition()
.duration(500)
.attr("width", x)
.attr("height", y.rangeBand())
;
var rules = vis.selectAll("g.rule")
.data(x.ticks(10))
.enter().append("svg:g")
.attr("class", "rule")
.attr("transform", function(d) { return "translate(" + x(d) + ", 0)"; });
rules.append("svg:line")
.attr("y1", h)
.attr("y2", h + 6)
.attr("x1", labelpad)
.attr("x2", labelpad)
.attr("stroke", "black");
rules.append("svg:line")
.attr("y1", 0)
.attr("y2", h)
.attr("x1", labelpad)
.attr("x2", labelpad)
.attr("stroke", "white")
.attr("stroke-opacity", .3);
어떻게 프로그래밍 방식으로 추가하고 다른 막대를 제거하고 기존의 것들/아래로 밀어 수 있도록 데이터를 변경할 수 있습니까?
답장을 보내 주셔서 감사합니다. d3에 처음 생겼습니다 - 언급 한 키 사용법을 보여주는 자습서 나 예제를 알고 있습니까? 내 updateChart() 함수는 어떻게 생겼을까요? 전환을위한 코드를 시도 할 때 차트가 표시되지 않습니다. d3_selection (groups)의 d3.v2.js에서 "Uncaught Error : SYNTAX_ERR : DOM Exception 12"가 표시됩니다 (두 번째 호출에서 오타가 이미 수정되었습니다. 세미콜론 대신) – Hokascha
이 코드를 실행하지 않았으므로 다른 문제가있을 수 있습니다. 필자는 요소 추가/제거를 위해 입력/종료 함수를 사용하는 아이디어를 보여 주려고했습니다. – Glenn
다음은 자습서 페이지입니다. https://github.com/mbostock/d3/wiki/ 자습서 – Glenn