【 D3.js 入门系列 --- 2 】 如何使用数据和选择元素

时间:2021-11-18 23:24:56

接着上一讲的内容,这次讨论如何选择元素和使用数据。
    现在页面中有三行文字,代码为:

  1. <p>Hello World 1</p>
  2. <p>Hello World 2</p>
  3. <p>Hello World 3</p>

定义一个集合set,里面有三个元素:

  1. var set = ["I like dog","I like cat","I like snake"];

要用这三个字符串给分别给上面的三个<p>赋值,代码如下:

  1. var sp = d3.select("body").selectAll("p");   //选择元素
  2. sp.data(set)             //使用数据集合
  3. .text(function(d,i){
  4. return d;
  5. });

上面第一行表示的是选择body里的所有p,再将这个集合赋值给一个变量p。第二行是表明要使用数据集合set,第三行表示要改变p里的文本内容。注意到后面有一个函数function(d,i),这是为了分别使用数据集合set里的元素。

如果不适用数据集合set,想要将所有文本都变为相同的字符串(如都变成China),只需:

  1. sp.text("China");

即可。如果要使用集合分别赋值,要使用函数function(d,i),这个函数的第一个参数的意思是datum(数据),第二个参数的意思是index(索引),要注意,当使用数据函数data指定了数据后,数据集合set和你选择的p集合是一一对应的(如果set和p的数量正好一致的情况,不一样的情况以后再讨论)。函数里面只有一个语句 return d; , 表示直接返回数据,意思是对于每一个索引i,都直接返回数据d。 d3.js会自动按先后顺序为各个p赋值的。

结果如下图:

【 D3.js 入门系列 --- 2 】 如何使用数据和选择元素

如果我们想只选择其中一个元素进行操作,假设只想操作Hello World 3,怎么办呢?

有两种方法:

一、为第三个p赋予一个id,即

  1. <p id="p3">Hello World 3</p>

再选择

  1. var sp = d3.select("body").select("#p3");   //选择元素

再进行操作即可。

二、在function(d,i)里操作,例如

  1. sp.text(function(d,i){
  2. if(i==2){
  3. ....
  4. }
  5. });

来自:博客首页为: http://www.ourd3js.com/  ,csdn博客首页为:http://blog.csdn.net/lzhlzz/。转载请注明出处,谢谢。

【 D3.js 入门系列 --- 2 】 如何使用数据和选择元素的更多相关文章

  1. 【 D3&period;js 入门系列 — 2 】 绑定数据和选择元素

    1. 如何绑定数据 D3 有一个很独特的功能:能将数据绑定到 DOM 上,也就是绑定到文档上.这么说可能不好理解,例如网页中有段落元素<p>,我们可以将整数 5 与 <p>绑定 ...

  2. 【 D3&period;js 入门系列 --- 2&period;1 】 关于如何选择,插入,删除元素

    在D3.js中,选择元素的函数有两个:select 和 selectAll . 先说明一下它们的区别: select 是选择所有指定元素的第一个 selectAll 是选择指定元素的全部(以用于后面同 ...

  3. 【 D3&period;js 入门系列 --- 2&period;1 】 关于怎样选择,插入,删除元素

    本人的个人博客首页为: http://www.ourd3js.com/  ,csdn博客首页为:http://blog.csdn.net/lzhlzz/. 转载请注明出处,谢谢. 在D3.js中,选择 ...

  4. 【 D3&period;js 入门系列 — 11 】 入门总结

    D3 新专题首页 一转眼,这个入门系列已经积累了二十二篇文章之多,我想作为 D3.js 这款数据可视化工具的入门来说已经足够了.相信仅仅要看完本系列.以后全然能够在辅以查询的情况下完毕大部分可视化工作 ...

  5. 【 D3&period;js 入门系列 --- 2 】 怎样使用数据和选择元素

    本人的个人博客首页为: http://www.ourd3js.com/  ,csdn博客首页为:http://blog.csdn.net/lzhlzz/. 转载请注明出处,谢谢. 接着上一讲的内容,这 ...

  6. 【 D3&period;js 入门系列 --- 7 】 理解 update&comma; enter&comma; exit 的使用

    在前面几节中反复出现了如下代码: svg.selectAll("rect") .data(dataset) .enter() .append("rect") 当 ...

  7. 【 D3&period;js 入门系列 --- 3 】 做一个简单的图表!

    前面说了几节,都是对文字进行处理,这一节中将用 D3.js 做一个简单的柱形图. 做柱形图有很多种方法,比如用 HTML 的 div 标签,或用 svg . 推荐用 SVG 来做各种图形.SVG 意为 ...

  8. 【 D3&period;js 入门系列 --- 0 】 简介和安装

    D3的全称是(Data-Driven Documents),顾名思义可以知道是一个关于数据驱动的文档的javascript类库.如果你不知道什么是javascript,请先学习javascript的相 ...

  9. 【 D3&period;js 入门系列 — 3 】 做一个简单的图表!

    图1. 柱形图 1. 柱形图 前几章的例子,都是对文字进行处理.本章中将用 D3 做一个简单的柱形图.制作柱形图有很多种方法,比如用 HTML 的 <div> 标签,或在 SVG 上绘制 ...

随机推荐

  1. popen使用不当引起产生僵尸进程

    FILE * popen(const char * command, const char * type)popen函数会通过fork产生子进程,然后从子进程中调用/bin/sh -c执行参数comm ...

  2. Java集合框架知识总结

    两大体系:Collection,Map 一.Collection: List 接口 : List:里面对象全部是有序的(通过三种方法来遍历) ArrayList,LinkedList,Vertor A ...

  3. 【Selenium2&plus;Python】定位

    定位Frame driver.switch_to_frame("frameID") 多窗口切换 #获得当前窗口 nowhandle = driver.current_window_ ...

  4. Grand Theft Auto V 图形研究(2)

    原文链接 http://www.adriancourreges.com/blog/2015/11/02/gta-v-graphics-study-part-2/   Level of Detail 如 ...

  5. C&num;中Application&period;DoEvents&lpar;&rpar;的作用

    Visual Studio里的摘要:处理当前在消息队列中的所有 Windows 消息. 交出CPU控制权,让系统可以处理队列中的所有Windows消息,比如在大运算量循环内,加Application. ...

  6. 【uva1502&sol;hdu4117-GRE Words】DP&plus;线段树优化&plus;AC自动机

    这题我的代码在hdu上AC,在uva上WA. 题意:按顺序输入n个串以及它的权值di,要求在其中选取一些串,前一个必须是后一个的子串.问d值的和最大是多少. (1≤n≤2×10^4 ,串的总长度&lt ...

  7. &lbrack;HIve - LanguageManual&rsqb; Hive Operators and User-Defined Functions &lpar;UDFs&rpar;

    Hive Operators and User-Defined Functions (UDFs) Hive Operators and User-Defined Functions (UDFs) Bu ...

  8. webservice基本功能介绍

    WebService, 能使得运行在不同机器上的不同应用无须借助附加的.专门的第三方软件或硬件, 就可相互交换数据或集成.依据WebService规范实施的应用之间, 无论它们所使用的语言. 平台或内 ...

  9. 原生js移动端滑动事件

    移动端触屏滑动的效果其实就是图片轮播,在PC的页面上很好实现,绑定click和mouseover等事件来完成.但是在移动设备上,要实现这种轮播的效果,就需要用到核心的touch事件.处理touch事件 ...

  10. learning makefile &period;PHONY