本人的我的博客首页为: http://www.ourd3js.com/ ,csdn博客首页为:http://blog.csdn.net/lzhlzz/。html
转载请注明出处,谢谢。函数
接着上一讲的内容,此次讨论怎样选择元素和使用数据。
现在页面中有三行文字。代码为:.net
<p>Hello World 1</p> <p>Hello World 2</p> <p>Hello World 3</p>
var set = ["I like dog","I like cat","I like snake"];
var sp = d3.select("body").selectAll("p"); //选择元素 sp.data(set) //使用数据集合 .text(function(d,i){ return d; });上面第一行表示的是选择body里的所有p,再将这个集合赋值给一个变量p。
第二行是代表要使用数据集合set,第三行表示要改变p里的文本内容。注意到后面有一个函数funciont(d,i)。这是为了分别使用数据集合set里的元素。code
假设不适用数据集合set,想要将所有文本都变为一样的字符串(如都变成China)。仅仅需:htm
sp.text("China");就能够。假设要使用集合分别赋值,要使用函数function(d,i),这个函数的第一个參数的意思是datum(数据),第二个參数的意思是index(索引),要注意,当使用数据函数data指定了数据后。数据集合set和你选择的p集合是一一相应的(假设set和p的数量正好一致的状况,不同的状况之后再讨论)。函数里面仅仅有一个语句 return d; , 表示直接返回数据,意思是对于每一个索引i。都直接返回数据d。
d3.js会本身主动按前后顺序为各个p赋值的。blog
结果例如如下图:索引
若是咱们想仅仅选择当中一个元素进行操做,若是仅仅想操做Hello World 3,怎么办呢?ip
有两种方法:ci
1、为第三个p赋予一个id,即字符串
<p id="p3">Hello World 3</p>再选择
var sp = d3.select("body").select("#p3"); //选择元素再进行操做就能够。
2、在function(d,i)里操做,好比
sp.text(function(d,i){ if(i==2){ .... } });