.DS_Store
# use-d3-v3-to-build-interactive-charts-with-javascript
#chartArea {
width: 400px;
height: 300px;
background-color: #CCC;
}
.bubble {
display: inline-block;
fill: purple;
fill-opacity: 0.5;
stroke: black;
stroke-weight: 1px;
}
<!DOCTYPE html>
<html>
<head>
<title>D3 - Data Driven Documents</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.16/d3.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.3/underscore.js"></script>
<link rel="stylesheet" href="app.css">
</head>
<body>
<div id="chartArea"></div>
<script src="script.js"></script>
</body>
</html>
var dataset = _.map(_.range(25), function (i) {
return {
x: Math.random() * 100,
y: Math.random() * 100,
r: Math.random() * 30
};
});
var margin = {top: 0, right: 0, bottom: 0, left: 0};
var w = 400 - margin.left - margin.right,
h = 300 - margin.top - margin.bottom;
var svg = d3.select('#chartArea').append('svg')
.attr('width', w + margin.left + margin.right)
.attr('height', h + margin.top + margin.bottom)
.append('g')
.attr('transform', 'translate(' + margin.left + ', ' + margin.top + ')');
var xScale = d3.scale.linear()
.domain([0, 100])
.range([0, w]);
var yScale = d3.scale.linear()
.domain([0, d3.max(dataset, function (d) {
return d.y;
})])
.range([h, 0]);
svg.selectAll('circle')
.data(dataset)
.enter()
.append('circle')
.attr('class', 'bubble')
.attr('cx', function (d) {
return xScale(d.x);
})
.attr('cy', function (d) {
return yScale(d.y);
})
.attr('r', function (d) {
return d.r;
});