本站消息

站长简介/公众号


站长简介:高级软件工程师,曾在阿里云,每日优鲜从事全栈开发工作,利用周末时间开发出本站,欢迎关注我的微信公众号:程序员总部,程序员的家,探索程序员的人生之路!分享IT最新技术,关注行业最新动向,让你永不落伍。了解同行们的工资,生活工作中的酸甜苦辣,谋求程序员的最终出路!

 价值13000svip视频教程,前端大神匠心打造,零基础前端开发工程师视频教程全套,基础+进阶+项目实战,包含课件和源码

  出租广告位,需要合作请联系站长


+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

暂无数据

我可以在保留其实例/状态的同时移动 iframe 吗?

发布于2021-12-03 00:24     阅读(952)     评论(0)     点赞(17)     收藏(5)


如果我在一个节点上设置了一个 iframe,我可以将它移动到另一个节点,同时保留其当前状态吗?

我必须为此保留 IE11 支持

const iframe = document.querySelector('#my-frame')

document.querySelector('#new-node').appendChild(iframe)
document.querySelector('#old-node').removeChild(iframe)
div{
  border: 1px dashed black;
}
<div id="old-node">
  Old node
  <iframe id="my-frame" src="https://example.com"></iframe>
</div>
<div id="new-node">
  New node
</div>


解决方案


你几乎是对的。

但是,由于 DOM 元素一次只能有一个父.appendChild元素,因此会自动从其当前父元素中删除该元素(如果它已经在 DOM 中)。

因此,在您的情况下,当您调用 时.removeChild,该元素不再是旧父元素的子元素,并且.removeChild会抛出一个DOMException.

你有两种方法:

  • 将呼叫移至.removeChild之前.appendChild

    const iframe = document.querySelector('#my-frame')
    
    document.querySelector('#old-node').removeChild(iframe)
    document.querySelector('#new-node').appendChild(iframe)
    
  • 但是,您甚至可以省略对 的调用.removeChild

    const iframe = document.querySelector('#my-frame')
    
    document.querySelector('#new-node').appendChild(iframe)
    



所属网站分类: 技术文章 > 问答

作者:黑洞官方问答小能手

链接:http://www.qianduanheidong.com/blog/article/246446/ae270c3058b1599e416a/

来源:前端黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

17 0
收藏该文
已收藏

评论内容:(最多支持255个字符)