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
  • 相关阅读:
    [OS] 修改屏幕分辨率(用Remote Desktop Connection 或者 用工具:Remote Desktop Connection Manager)
    英文单词通用缩写表
    [Selenium] 怎样判断是否适合自动化测试
    [Selenium] Java代码获取,设置屏幕分辨率
    [Selenium] Java代码获取屏幕分辨率
    [Selenium] 最大化或自定义浏览器的大小
    跟我一起玩Win32开发(7):多边形窗口
    跟我一起玩Win32开发(5):具有单选标记的菜单
    跟我一起玩Win32开发(6):创建右键菜单
    跟我一起玩Win32开发(4):创建菜单
  • 原文地址:https://www.cnblogs.com/cupid10/p/15617608.html
Copyright © 2011-2022 走看看