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


        本人的个人博客首页为: http://www.ourd3js.com/  ,csdn博客首页为:http://blog.csdn.net/lzhlzz/

    转载请注明出处,谢谢。


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

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

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

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

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

    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里的元素。

        假设不适用数据集合set,想要将全部文本都变为同样的字符串(如都变成China)。仅仅需:

    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,即

    <p id="p3">Hello World 3</p>
        再选择

    var sp = d3.select("body").select("#p3");   //选择元素
    再进行操作就可以。


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

    sp.text(function(d,i){
    	if(i==2){
    	 ....
    	}
    });	






  • 相关阅读:
    第一课时之导读
    python学习之第十六课时--缩进(indentation)
    python学习之第十六课时--函数的作用及定义
    python学习之第十五课时--存址方式及拷贝
    Linux学习之第七课时--链接(link)文件
    Linux学习之第六课时--文件和目录操作管理命令
    Linux学习之第五课时--文本编辑器
    TOJ--1162---dfs(回溯)
    TOJ---3128---bfs(打印路径)
    TOJ---1502---map真强大
  • 原文地址:https://www.cnblogs.com/blfshiye/p/5401239.html
Copyright © 2020-2023  润新知