Ive начал с примера "Давайте сделаем гистограмму" здесь: http://bost.ocks.org/mike/bar/
И мне трудно понять, как сделать очень простую гистограмму, сделанную с обновлением элементов HTML5 новыми данными. Вот мой код:
<!DOCTYPE html>
<html>
<head>
<style>
#work_queues_chart div {
font-size: 0.5em;
font-family: sans-serif;
color: white;
background-color: steelblue;
text-align: right;
padding: 0.5em;
margin: 0.2em;
}
</style>
<script src="http://d3js.org/d3.v3.min.js" charset="utf-8" />
<script type="text/javascript">
function init() {
var data = [0, 0, 0, 0, 0, 0];
/* scale is a function that normalizes a value in data into the range 0-98 */
var scale = d3.scale.linear()
.domain([0, 200])
.range([0, 98]);
var bars = d3.select("#work_queues_chart")
.selectAll("div")
.data(data)
.enter().append("div");
bars.style("width", function(d) { return scale(d) + "%"; })
bars.text(function(d) { return d; });
}
function update() {
var data = [4, 8, 15, 16, 23, 42];
/* http://stackoverflow.com/info/14958825/dynamically-update-chart-data-in-d3 */
}
window.onload = init;
</script>
</head>
<body>
<div id="work_queues_chart" />
<button onclick="update()">Update</button>
</body>
</html>
Вопрос в том, что я помещаю в update(), чтобы заставить бары рисовать новыми данными? Я попробовал d3.select("#work_queues_chart").selectAll("div").data(data)
с новыми данными, но Im неясно, что должно произойти дальше (или это был правильный ход).