D3js-对柱状图的增,删,排序

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<%

String path = request.getContextPath();

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";

%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<base href="<%=basePath%>">

<title>D3 增加 删除 排序 柱状图</title>

<meta http-equiv="pragma" content="no-cache">

<meta http-equiv="cache-control" content="no-cache">

<meta http-equiv="expires" content="0">

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">

<meta http-equiv="description" content="This is my page">

<!--

<link rel="stylesheet" type="text/css" href="styles.css">

-->

</head>

<body>

<script type="text/javascript" src="js/d3/d3.js"></script>

<script type="text/javascript" src="js/d3/d3.min.js"></script>

<script type="text/javascript">

//定义变量

var width =1000;

var height=600;

var dataset=[];

var svg = d3.select("body").append("svg")

.attr("width".width)

.attr("height",height);

for(var i=0;i<5;i++)

{

dataset[i]=Math.floor(Math.random()*100);

}

console.log(dataset);

//外边框

var padding={top:20,right:20,bottom:20,left:20};

//矩形宽度 包括空白

var rectStep=35;

//矩形宽度 不包括空白

var rectWidth=30;

//绘制矩形

function draw()

{

//1-----------------------------------

//获取矩形updata部分

var updateRect = svg.selectAll("rect")

.data(dataset);

//获取矩形的enter部分

var enterRect =updateRect.enter();

//获取矩形的exit部分

var exitRect =updateRect.exit();

//获取矩形update方法的处理

updateRect.attr("fill","steelblue")

//矩形坐标

.attr("x",function(d,i)

{

return padding.left+i*rectStep;

})

.attr("y",function(d,i)

{

return height-padding.bottom-d;

})

//矩形的高宽

.attr("width",rectWidth)

.attr("height",function(d,i)

{

return d;

});

//获取矩形 enter方法的处理

enterRect.append("rect")

.attr("fill","steelblue")

//矩形坐标

.attr("x",function(d,i)

{

return padding.left+i*rectStep;

})

.attr("y",function(d,i)

{

return height-padding.bottom-d;

})

//矩形的高宽

.attr("width",rectWidth)

.attr("height",function(d,i)

{

return d;

});

//获取矩形exit方法的处理

exitRect.remove();

//2--------------------------------------

//获取文字update的处理

var updateText = svg.selectAll("text")

.data(dataset);

var enterText = updateText.enter();

var exitText = updateText.exit();

updateText.attr("fill","white")

.attr("font-size","14px")

.attr("text-anchor","middle")

.attr("x",function(d,i)

{

return padding.left+i*rectStep;

})

.attr("y",function(d,i)

{

return height-padding.bottom-d;

})

.attr("dx",rectWidth/2)

.attr("dy","1em")

.text(function(d,i)

{

return d;

});

enterText.append("text")

.attr("fill","white")

.attr("font-size","14px")

.attr("text-anchor","middle")

.attr("x",function(d,i)

{

return padding.left+i*rectStep;

})

.attr("y",function(d,i)

{

return height-padding.bottom-d;

})

.attr("dx",rectWidth/2)

.attr("dy","1em")

.text(function(d,i)

{

return d;

});

exitText.remove();

}

//调用绘图函数

draw();

//排序

function sortData()

{

dataset.sort(d3.ascending);

draw();

}

//增加

function addData()

{

dataset.push(Math.floor(Math.random()*100));

draw();

}

//删除

function deleteData()

{

//选中所有条

dataset.shift();

var bars = svg.selectAll("rect")

.data(dataset);

bars.exit()

.remove();

draw();

}

</script>

<br/>

<div>

<button type="button" onclick="sortData()">排序</button>

<button type="button" onclick="addData()">增加</button>

<button type="button" onclick="deleteData()">删除</button>

</div>

</body>

</html>

参考 网站:http://www.ourd3js.com/wordpress/?p=841

http://blog.csdn.net/tianxuzhang/article/details/14086627

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-08-14 18:06:11

D3js-对柱状图的增,删,排序的相关文章

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform)让用户方便的操作数据库中的数据. 什么是ADO.NET 是一组库类,System.Data. Ado.net组成 Connection:用来连接数据库 Command:用来执行SQL语句 DataReader:只读.只进的结果集,一条一条读取数据(SteamReader.XmlReader) Da

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

2016/05/05 smarty 增 删 改

共  八个页面 ①login.php 1 <?php 2 include("init.inc.php"); 3 4 $smarty->display("login.html"); 5 ?> ②login.html  显示模板  在templates模板文件夹中 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset=&q

Android 增,删,改,查 通讯录中的联系人

一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission> <uses-permission android:name="android.permission.WRITE_CONTACTS"></uses-permission>