【 D3.js 入门系列 --- 2 】 如何使用数据和选择元素
2016-08-27 14:56
337 查看
接着上一讲的内容,这次讨论如何选择元素和使用数据。
现在页面中有三行文字,代码为:
[html] view plain copy
<p>Hello World 1</p>
<p>Hello World 2</p>
<p>Hello World 3</p>
定义一个集合set,里面有三个元素:
[html] view plain copy
var set = ["I like dog","I like cat","I like snake"];
要用这三个字符串给分别给上面的三个<p>赋值,代码如下:
[html] view plain copy
var sp = d3.select("body").selectAll("p"); //选择元素
sp.data(set) //使用数据集合
.text(function(d,i){
return d;
});
上面第一行表示的是选择body里的所有p,再将这个集合赋值给一个变量p。第二行是表明要使用数据集合set,第三行表示要改变p里的文本内容。注意到后面有一个函数function(d,i),这是为了分别使用数据集合set里的元素。
如果不适用数据集合set,想要将所有文本都变为相同的字符串(如都变成China),只需:
[html] view plain copy
sp.text("China");
即可。如果要使用集合分别赋值,要使用函数function(d,i),这个函数的第一个参数的意思是datum(数据),第二个参数的意思是index(索引),要注意,当使用数据函数data指定了数据后,数据集合set和你选择的p集合是一一对应的(如果set和p的数量正好一致的情况,不一样的情况以后再讨论)。函数里面只有一个语句 return d; , 表示直接返回数据,意思是对于每一个索引i,都直接返回数据d。 d3.js会自动按先后顺序为各个p赋值的。
结果如下图:
![](http://img.blog.csdn.net/20140529110058921?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbHpobHp6/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
如果我们想只选择其中一个元素进行操作,假设只想操作Hello World 3,怎么办呢?
有两种方法:
一、为第三个p赋予一个id,即
[html] view plain copy
<p id="p3">Hello World 3</p>
再选择
[html] view plain copy
var sp = d3.select("body").select("#p3"); //选择元素
再进行操作即可。
二、在function(d,i)里操作,例如
[html] view plain copy
sp.text(function(d,i){
if(i==2){
....
}
});
来自:博客首页为: http://www.ourd3js.com/ ,csdn博客首页为:http://blog.csdn.net/lzhlzz/。转载请注明出处,谢谢。
现在页面中有三行文字,代码为:
[html] view plain copy
<p>Hello World 1</p>
<p>Hello World 2</p>
<p>Hello World 3</p>
定义一个集合set,里面有三个元素:
[html] view plain copy
var set = ["I like dog","I like cat","I like snake"];
要用这三个字符串给分别给上面的三个<p>赋值,代码如下:
[html] view plain copy
var sp = d3.select("body").selectAll("p"); //选择元素
sp.data(set) //使用数据集合
.text(function(d,i){
return d;
});
上面第一行表示的是选择body里的所有p,再将这个集合赋值给一个变量p。第二行是表明要使用数据集合set,第三行表示要改变p里的文本内容。注意到后面有一个函数function(d,i),这是为了分别使用数据集合set里的元素。
如果不适用数据集合set,想要将所有文本都变为相同的字符串(如都变成China),只需:
[html] view plain copy
sp.text("China");
即可。如果要使用集合分别赋值,要使用函数function(d,i),这个函数的第一个参数的意思是datum(数据),第二个参数的意思是index(索引),要注意,当使用数据函数data指定了数据后,数据集合set和你选择的p集合是一一对应的(如果set和p的数量正好一致的情况,不一样的情况以后再讨论)。函数里面只有一个语句 return d; , 表示直接返回数据,意思是对于每一个索引i,都直接返回数据d。 d3.js会自动按先后顺序为各个p赋值的。
结果如下图:
如果我们想只选择其中一个元素进行操作,假设只想操作Hello World 3,怎么办呢?
有两种方法:
一、为第三个p赋予一个id,即
[html] view plain copy
<p id="p3">Hello World 3</p>
再选择
[html] view plain copy
var sp = d3.select("body").select("#p3"); //选择元素
再进行操作即可。
二、在function(d,i)里操作,例如
[html] view plain copy
sp.text(function(d,i){
if(i==2){
....
}
});
来自:博客首页为: http://www.ourd3js.com/ ,csdn博客首页为:http://blog.csdn.net/lzhlzz/。转载请注明出处,谢谢。
相关文章推荐
- [Javascript] Promise
- JSON对象
- JavaScript setTimeout() clearTimeout() 方法
- JS插件检测
- jsp页面表格中<textarea>标签的菜鸟级错误
- 通过Ajax技术,将数组类型数据转换为JSON格式的对象
- 轻松掌握JavaScript装饰者模式
- linkbutton.js
- canvas动画之文字粒子效果
- 图片懒加载解决方案 lazyload.js
- javascript Date format(js日期格式化)
- 轻松掌握:JavaScript装饰者模式
- 通过js获取当前网页的url信息
- 【JavaScript】正则表达式
- [转]解析json:与array,list,map,bean,xml相互转化
- video.js--很赞的H5视频播放库
- jsp延迟加载图片
- 【 D3.js 入门系列 --- 1 】 第一个程序HelloWorld
- JSP EL表达式取URL里传来的值
- 好文要顶之 --- 简单粗暴地理解 JavaScript 原型链