D3 柱形堆叠图

<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8">
  <meta name="Generator" content="EditPlus®">
  <meta name="Author" content="">
  <meta name="Keywords" content="">
  <meta name="Description" content="">
  <title>Document</title>
  <script src="d3.js"></script>
  
<style>

body {
  font: 10px sans-serif;
  color:#ccc !important;
}

.axis path,
.axis line {
  fill: none;
  stroke: #888;
  shape-rendering: crispEdges;
  color:#ccc !important;
}

.bar {
  fill: steelblue;
  color:#ccc !important;
}

.x.axis path {
  display: none; 
  color:#ccc !important;
}

.fd{
	width:18px;
	height:1px;
	margin-top:2px;
	background-color: green;
}
#container{
	background:#143948;
	width:1050px;
	color:#ccc !important;
}
</style>
 </head>
 <body>
  <div id="container"></div>
 <script>

var margin = {top: 20, right: 20, bottom: 30, left: 40},
    width = 960 - margin.left - margin.right,
    height = 500 - margin.top - margin.bottom;

var x = d3.scale.ordinal()
    .rangeRoundBands([0, width], .1);

var y = d3.scale.linear()
    .rangeRound([height, 0]);

var color = d3.scale.ordinal()
    .range(["#2D72A7", "#58CFFF", "#fff"]);

var xAxis = d3.svg.axis()
    .scale(x)
    .orient("bottom");

var yAxis = d3.svg.axis()
    .scale(y)
    .orient("left")
    .tickFormat(d3.format(".2s"));

var svg = d3.select("#container").append("svg")
    .attr("width", width + margin.left + margin.right)
    .attr("height", height + margin.top + margin.bottom)
	.append("g")
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")");

d3.csv("data.csv", function(error, data) {
  color.domain(d3.keys(data[0]).filter(function(key) { return key !== "State"; }));

  data.forEach(function(d) {
    var y0 = 0;
    d.ages = color.domain().map(function(name) { return {name: name, y0: y0, y1: y0 += +d[name]}; });
    d.total = d.ages[d.ages.length - 1].y1;
  });

  data.sort(function(a, b) { return b.total - a.total; });

  x.domain(data.map(function(d) { return d.State; }));
  y.domain([0, d3.max(data, function(d) { return d.total; })]);

  svg.append("g")
      .attr("class", "x axis")
      .attr("transform", "translate(0," + height + ")")
      .call(xAxis);

  svg.append("g")
      .attr("class", "y axis")
      .call(yAxis)
    .append("text")
      .attr("transform", "rotate(-90)")
      .attr("y", 6)
      .attr("dy", ".71em")
      .style("text-anchor", "end")
      //.text("Population");

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

  state.selectAll("rect")
      .data(function(d) { return d.ages; })
      .enter().append("rect")
      .attr("width", x.rangeBand())
      .attr("y", function(d) { return y(d.y1); })
      .attr("height", function(d) { return y(d.y0) - y(d.y1); })
      .style("fill", function(d) { return color(d.name); });

  var legend = svg.selectAll(".legend")
      .data(color.domain().slice().reverse())
	  .enter().append("g")
      .attr("class", "legend")
	  .style("font-color",'white')
      .attr("transform", function(d, i) { return "translate(0," + i * 20 + ")"; });

  legend.append("rect")
      .attr("x", width - 18)
      .attr("width", 18)
      .attr("height", 18)
      .style("fill", color);

  legend.append("text")
      .attr("x", width - 24)
      .attr("y", 9)
      .attr("dy", "0.35em")
      .style("text-anchor", "end")
      .text(function(d) { return d; });

});
</script>
 </body>
</html>


数据data.csv

State,Current Seller,Same Manager,Same GMT 
CA,2704659,4499890,2159981 
FL,1140516,1938695,925060
GA,740521,1250460,557860  
IL,894368,1558919,725973  
MD,371787,651923,316873
MA,383568,701752,341713
MI,625526,1179503,585169 
MO,399450,690476,331543  
NJ,557421,1011656,478505 
NY,1208495,2141490,1058031 
OH,743750,1340492,646135 
PA,737462,1345341,679201  
TX,2027307,3277946,1420518 


效果图:


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
 你手头有一些数据,想做成漂亮的表放到网站上?好主意,通过浏览器来跨平台实现数据可视化是正确的选择。什么,你还想让表能够响应用户操作?没问题,交互式表比静态片更能吸引人去探究本源。好啦,要生成通过浏览器展示的动态表,目前热门的Web数据可视化库——D3。   《灵程序设计丛书·数据可视化实战:使用D3设计交互式表》这本书很有意思,而且对读者要求不高。不需要知道什么是数据可视化,也不用有太多Web开发背景就能看懂它。不信?翻一翻就知道这是一本既好玩又实用的动手指南啦!看完这本书你会怎么样呢?   掌握必要的HTML、CSS、JavaScript和SVG基础知识;   学会基于数据在网页里生成元素和为它们设置样式的技巧;   能够生成条、散点、饼、堆和力导向;   使用平滑的过渡动画来展示数据的变化;   赋予表动态交互能力,响应用户从不同角度探索数据的请求;   收集数据和创建自定义的地;   另外,《灵程序设计丛书·数据可视化实战:使用D3设计交互式表》100多个代码示例都可以在线浏览! 【电子版来自互联网,仅供预览及学习交流 使用,不可用于商业用途,如有版权问题,请联系删除,支持正版,喜欢的 请购买正版书籍: https://e.jd.com/30336473.html】
以下是用d3.js画堆柱状的代码示例: ```javascript // 设置数据 var data = [ {category: 'A', value1: 10, value2: 20, value3: 30}, {category: 'B', value1: 15, value2: 25, value3: 35}, {category: 'C', value1: 20, value2: 30, value3: 40}, {category: 'D', value1: 25, value2: 35, value3: 45}, ]; // 设置画布大小和边距 var margin = {top: 20, right: 20, bottom: 30, left: 40}, width = 600 - margin.left - margin.right, height = 400 - margin.top - margin.bottom; // 创建 SVG 元素 var svg = d3.select("body").append("svg") .attr("width", width + margin.left + margin.right) .attr("height", height + margin.top + margin.bottom) .append("g") .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); // 设置 x 和 y 轴的比例尺 var x = d3.scaleBand() .range([0, width]) .padding(0.1) .domain(data.map(function(d) { return d.category; })); var y = d3.scaleLinear() .range([height, 0]) .domain([0, d3.max(data, function(d) { return d.value1 + d.value2 + d.value3; })]); // 定义颜色比例尺 var color = d3.scaleOrdinal() .range(["#98abc5", "#8a89a6", "#7b6888"]); // 定义堆函数 var stack = d3.stack() .keys(["value1", "value2", "value3"]) .order(d3.stackOrderNone) .offset(d3.stackOffsetNone); // 堆数据 var series = stack(data); // 添加 x 轴 svg.append("g") .attr("class", "axis") .attr("transform", "translate(0," + height + ")") .call(d3.axisBottom(x)); // 添加 y 轴 svg.append("g") .attr("class", "axis") .call(d3.axisLeft(y).ticks(null, "s")) .append("text") .attr("x", 2) .attr("y", y(y.ticks().pop()) + 0.5) .attr("dy", "0.32em") .attr("fill", "#000") .attr("font-weight", "bold") .attr("text-anchor", "start") .text("Value"); // 添加堆柱状 svg.selectAll("g.layer") .data(series) .enter().append("g") .attr("class", "layer") .style("fill", function(d, i) { return color(i); }) .selectAll("rect") .data(function(d) { return d; }) .enter().append("rect") .attr("x", function(d) { return x(d.data.category); }) .attr("y", function(d) { return y(d[1]); }) .attr("height", function(d) { return y(d[0]) - y(d[1]); }) .attr("width", x.bandwidth()); // 添加例 var legend = svg.selectAll(".legend") .data(color.domain().slice().reverse()) .enter().append("g") .attr("class", "legend") .attr("transform", function(d, i) { return "translate(0," + i * 20 + ")"; }); legend.append("rect") .attr("x", width - 18) .attr("width", 18) .attr("height", 18) .style("fill", color); legend.append("text") .attr("x", width - 24) .attr("y", 9) .attr("dy", ".35em") .style("text-anchor", "end") .text(function(d) { return d; }); ``` 这段代码会生成一个堆柱状,其中每个类别有三个值,分别用不同的颜色表示。你可以根据需要修改数据和样式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值