zoukankan      html  css  js  c++  java
  • 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
    
    请用今天的努力,让明天没有遗憾。
  • 相关阅读:
    第六周进度条
    团队开发需求分析视频连接
    敏捷开发综述
    数组2--数组首尾相接,求最大子数组
    数组1--求一个数的最大子数组
    第四周进度条
    四则运算3
    第三周进度条
    第二周进度条
    单元测试
  • 原文地址:https://www.cnblogs.com/cupid10/p/14694299.html
Copyright © 2011-2022 走看看