• D3选择元素和绑定数据


    D3选择、插入、删除元素
    d3.select():是选择所有指定元素的第一个
    d3.selectAll():是选择指定元素的全部
    
    <html>
    
    <head>
    	<meta charset="utf-8">
    	<title>HelloWorld</title>
    </head>
    
    <body>
    	<p>Apple</p>
    	<p id="second">Pear</p>
    	<p>Banana</p>
    	<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
    	<script>
    		// 选择所有的p元素
    		// var body = d3.select("body");
    		// var p = body.selectAll("p");
    
    		// 选择第一个p元素
    		// var p1 = d3.select("p");
    		// p1.style("color", "red");
    
    		// 选择第二个p元素
    		// var p2 = d3.select("#second");
    		// p2.style("color", "red");
    
    		// 在 body 中 id 为 second 的元素前添加一个段落元素。
    		// var body = d3.select("body");
    		// body.insert("p", "#second")
    		// 	.text("insert p element");
    
    		// 删除元素
    		var body = d3.select("body");
    		var p = body.select("#second");
    		p.remove();
    	</script>
    </body>
    
    </html>
    
    D3绑定数据

    D3 中是通过以下两个函数来绑定数据的:

    • datum():绑定一个数据到选择集上
    • data():绑定一个数组到选择集上,数组的各项值分别与选择集的各元素绑定

    相对而言,data() 比较常用。

    datum()
    <body>
    	<p>Apple</p>
    	<p>Pear</p>
    	<p>Banana</p>
    	<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
    	<script>
    		var str = "China";
    		var body = d3.select("body");
    		var p = body.selectAll("p");
    		p.datum(str);
    		// d 代表数据,也就是与某元素绑定的数据。
           // i 代表索引,代表数据的索引号,从 0 开始。
    		p.text(function (d, i) {
    			return "第 " + i + " 个元素绑定的数据是 " + d;
    		});
    	</script>
    </body>
    

    其结果如下:

    第 0 个元素绑定的数据是 China
    
    第 1 个元素绑定的数据是 China
    
    第 2 个元素绑定的数据是 China
    
    data()

    有一个数组,接下来要分别将数组的各元素绑定到三个段落元素上。

    var dataset = ["I like dog","I like cat","I like snake"];
    

    绑定之后,其对应关系的要求为:

    • Apple 与 I like dog 绑定
    • Pear 与 I like cat 绑定
    • Banana 与 I like snake 绑定

    调用 data() 绑定数据,并替换三个段落元素的字符串为被绑定的字符串,代码如下:

    <html>
    
    <head>
    	<meta charset="utf-8">
    	<title>HelloWorld</title>
    </head>
    
    <body>
    	<p>Apple</p>
    	<p>Pear</p>
    	<p>Banana</p>
    	<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
    	<script>
    	var dataset = ["I like dog","I like cat","I like snake"];
    	var body = d3.select("body");
    	var p = body.selectAll("p");
    	p.data(dataset)
    	.text(function(d,i){
    		return d;
    	})
    	</script>
    </body>
    
    </html>
    

    结果如下:

    I like dog
    
    I like cat
    
    I like snake
    
    请用今天的努力,让明天没有遗憾。
  • 相关阅读:
    c#生成验证码
    使用Linq导出数据到execl
    AspNetPager2.0.dll组件的使用
    <httpRuntime>属性值的解析
    帮助文档chm的制作
    关于table边框打印不显示的样式设置
    【Reporting Services 报表开发】— 如何设置报表分页列标题每一页都显示
    Microsoft Dynamics CRM4.0 创建单据的时候,自动生成单据编号的通用方法
    【Reporting Services 报表开发】— 总结
    出现“安全时间戳无效,因为其创建时间(“2013-10-30T14:42:07.861Z”)是将来的时间。当前时间为“2013-10-30T14:36:23.988Z”,允许的时钟偏差是“00:05:00””的原因
  • 原文地址:https://www.cnblogs.com/cupid10/p/14694299.html
Copyright © 2020-2023  润新知