理解D3js中的enter,exit方法

在我第一次使用D3js库写第一个图表的时候,就对他绑定数据的方法感到迷惑,当时怎么也不明白为什么要这样写来绑定数据。等到练习的次数多了,多的东西多了之后再回头看,原来一切都是那么理所应当,原来如此。

这就像是我们一生中遇到的很多事情一样,第一次无法接受,经过时间的沉淀,慢慢懂了,就不再耿耿于怀,变得释然。

但是我还是怕忘了此刻,所以马上写一篇文字总结一下。

<body>
    <p></p>
</body>
<script>
    var p = d3.select('body').selectAll('p');
    var dataset = [1,2,3,4,5,6,7,13];

    var update = p.data(dataset);
    var enter = update.enter();
    var exit = update.exit();
</script>

上边的HTML里边包含一个p标签,在JS脚本里边声明一个存放数据的数组dataset。

首先使用D3的selectAll()方法把所有的p标签选择出来,之后使用data() 方法为p标签集合绑定数据,并将所有的绑定了数据的p元素赋值给自己声明的update变量。

update 变量里包含所有已经存在的p标签,就上边的HTML来将就只有一个p标签。

enter变量包含的是dataset数组中的元素个数减去HTML中已经存在的元素个数的p标签(dataset中有8个元素,而HTML中有1个,因此enter中就有7个p标签元素),当数据中的元素个数大于HTML中已存在的元素个数时才能得到enter多出的那部分需要绑定数据的标签元素。

exit变量和enter 正好相反,当dataset中的数据元素个数少于HTML中需要绑定数据的元素个数时,就会得到多余出来的标签元素,这些多余出来的标签元素就存放在exit变量中。

这样enter()exit() 两个函数的含义就搞明白了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值