如何仅附加节点的子节点?

发布于 2025-02-10 05:19:21 字数 409 浏览 1 评论 0原文

假设以下节点(实际上不是这样生成的节点):

let outer = document.createElement('div');
outer.innerHTML = `
  <div>foo</div>
  <div>bar</div>
  .
  .
  .
  <div>whatever</div>
`;

现在我可以将ofter附加到另一个节点:

let body = document.querySelector('body');
body.append(outer);

但是如何仅附加offer> ofter 不丢失事件听众等吗?

Assuming the following node(s) (which is/are actually not generated like this):

let outer = document.createElement('div');
outer.innerHTML = `
  <div>foo</div>
  <div>bar</div>
  .
  .
  .
  <div>whatever</div>
`;

Now I can append outer to another node:

let body = document.querySelector('body');
body.append(outer);

But how to append only the inner of outer without loosing event listeners etc.?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

未央 2025-02-17 05:19:21

调用append()外部的每个孩子作为单独的参数,使用...语法来传播峰值。

body.append(...outer.children);

Call append() with each child of outer as a separate argument by using the ... syntax to spread an iterable.

body.append(...outer.children);
您的好友蓝忘机已上羡 2025-02-17 05:19:21

时,您不是在附加

要回答您的“不丢失事件处理程序” - 事实证明,当您没有委托

let outer = document.createElement('div');
outer.classList.add("outer")
outer.innerHTML = `
  <div class="foo" onclick="console.log('Foo clicked')">foo</div>
  <div class="bar">bar</div>
  <div>whatever</div>
`;

let body = document.querySelector('body');
body.append(outer);
body.append(...outer.children);
.outer { height:100px; width:100px; border: 1px solid red;}

与身体委将

let outer = document.createElement('div');
outer.classList.add("outer")
outer.innerHTML = `
  <div class="foo">foo</div>
  <div class="bar">bar</div>
  <div>whatever</div>
`;

let body = document.querySelector('body');
body.append(outer);
body.append(...outer.children);
body.addEventListener("click", e => {  
  const tgt = e.target;
  if (tgt.matches(".foo")) console.log("Foo clicked")
  else if (tgt.matches(".bar")) console.log("Bar clicked")
})
.outer { height:100px; width:100px; border: 1px solid red;}

To answer your "without losing event handlers" - it turns out your are not when you append

Without delegation

let outer = document.createElement('div');
outer.classList.add("outer")
outer.innerHTML = `
  <div class="foo" onclick="console.log('Foo clicked')">foo</div>
  <div class="bar">bar</div>
  <div>whatever</div>
`;

let body = document.querySelector('body');
body.append(outer);
body.append(...outer.children);
.outer { height:100px; width:100px; border: 1px solid red;}

With delegation from body

let outer = document.createElement('div');
outer.classList.add("outer")
outer.innerHTML = `
  <div class="foo">foo</div>
  <div class="bar">bar</div>
  <div>whatever</div>
`;

let body = document.querySelector('body');
body.append(outer);
body.append(...outer.children);
body.addEventListener("click", e => {  
  const tgt = e.target;
  if (tgt.matches(".foo")) console.log("Foo clicked")
  else if (tgt.matches(".bar")) console.log("Bar clicked")
})
.outer { height:100px; width:100px; border: 1px solid red;}

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文