首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >D3.js: select("body").selectAll("p")和selectAll("p")之间的区别?

D3.js: select("body").selectAll("p")和selectAll("p")之间的区别?
EN

Stack Overflow用户
提问于 2011-12-13 06:22:26
回答 1查看 6.2K关注 0票数 13

有谁知道有什么不同吗?

我的理解是两者都会返回相同的选择。

然而,当我做一个附加操作时,如果我使用selectAll("p"),它就不能工作。

例如,这是可行的:

代码语言:javascript
复制
var foo = d3.select("body")
            .selectAll("p")
            .data([1, 2, 3, 4]);

foo.enter.append("p")

虽然这不起作用:

代码语言:javascript
复制
var foo = d3.selectAll("p")
            .data([1, 2, 3, 4]);

foo.enter.append("p")

为什么后者不起作用?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-12-14 09:27:27

这里的简短答案是:“因为没有什么可以追加的。”虽然d3.selectAll("p")d3.select("body").selectAll("p")将选择相同的现有节点是正确的,但是选择body元素首先会为使用.append()方法添加的新节点设置上下文。

如果不选择body,就没有办法在DOM树中插入节点--我猜测d3试图将新节点附加到document对象,这会导致HIERARCHY_REQUEST_ERROR discussed here

票数 17
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8481737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档