我試圖讓這兩個divs叫bar1和bar2出現在另一個旁邊。我嘗試了一下svg和div id。不知道如何讓這兩個圖形並排。如何讓我的兩個d3圖形彼此相鄰?
這裏是BAR1:
var margin = {top: 20, right: 20, bottom: 30, left: 40};
var width = 360 - margin.left - margin.right,
height = 330 - margin.top - margin.bottom;
var chart1 = d3.select("#bar1")
.append("svg")
.attr('id', 'bar1svg')
.attr('width', width + margin.left + margin.right)
.attr('height', height + margin.top + margin.bottom);
var svg = d3.select("#bar1svg");
var x = d3.scaleBand().rangeRound([0, width]).padding(0.1),
y = d3.scaleLinear().rangeRound([height, 0]);
var g = chart1.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
d3.csv ("data/housingdata.csv", function(d) {
d.median_housing_prices = +d.median_housing_prices;
return d;
}, function(error, data) {
if (error) throw error;
x.domain(data.map(function(d) { return d.neighborhoods; }));
y.domain([0, d3.max(data, function(d) { return d.median_housing_prices; })]);
g.append("g")
.attr("class", "axis axis--x")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(x));
g.append("g")
.attr("class", "axis axis--y")
.call(d3.axisLeft(y).ticks(20, 's'))
.append("text")
.attr("transform", "rotate(-90)")
.attr("y", 6)
.attr("dy", "0.71em")
.attr("text-anchor", "end")
.text("Frequency");
g.selectAll(".bar")
.data(data)
.enter().append("rect")
.attr("class", "bar")
.attr("x", function(d) { return x(d.neighborhoods); })
.attr("y", function(d) { return y(d.median_housing_prices); })
.attr("width", x.bandwidth())
.attr("height", function(d) { return height - y(d.median_housing_prices); });
});
這裏是條2:
var chart2 = d3.select("#bar2")
.append("svg")
.attr('id', 'bar2svg')
.attr('width', width + margin.left + margin.right)
.attr('height', height + margin.top + margin.bottom);
var g2 = chart2.append("g2")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
d3.csv("data/housingdata2.csv", function(d) {
d.median_housing_prices = +d.median_housing_prices;
return d;
}, function(error, data) {
if (error) throw error;
x.domain(data.map(function(d) { return d.neighborhoods; }));
y.domain([0, d3.max(data, function(d) { return d.median_housing_prices; })]);
g2.append("g2")
.attr("class", "axis axis--x")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(x));
g2.append("g2")
.attr("class", "axis axis--y")
.call(d3.axisLeft(y).ticks(10, 's'))
.append("text")
.attr("transform", "rotate(-90)")
.attr("y", 6)
.attr("dy", "0.71em")
.attr("text-anchor", "end")
.text("Frequency");
g2.selectAll(".bar")
.data(data)
.enter().append("rect")
.attr("class", "bar")
.attr("x", function(d) { return x(d.neighborhoods); })
.attr("y", function(d) { return y(d.median_housing_prices); })
.attr("width", x.bandwidth())
.attr("height", function(d) { return height - y(d.median_housing_prices); });
});
這個問題不是D3相關的問題,而是一個簡單的CSS問題:爲div設置'float:left'。 –