javascript - dom用removechild删除时要先获取父元素,而insertbefore时就不用过去父元素。而可以直接使用
学习ing
学习ing 2017-06-14 10:53:43
[JavaScript讨论组]

<!DOCTYPE HTML>
<html lang="en-US">
<head>
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
    
    <button id='btn'>创建元素</button>
    
    <script type="text/javascript">
        
        var btn = document.getElementById('btn');
        
        //注册点击事件
        btn.onclick = function(){
            //创建一个元素
            var h1 = document.createElement('h1');
            h1.innerHTML = "这是新增h1标签";

            console.log( h1 );

            //使用appendChild的方式
            //document.body.appendChild( h1 );
            
            //使用insertBefore的方式
            //是在父元素中,先找一个节点,然后插入到它之前
            document.body.insertBefore(h1,btn); //新插入的节点是h1,作为第一个参数
        }

    </script>
</body>
</html>

<!DOCTYPE HTML>
<html lang="en-US">
<head>
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
    
    <p id="box">
        <h2>删除操作</h2>
        <p>段落1</p>
    </p>
    
    <button id='btn'>删除</button>
    
    <script type="text/javascript">
        
        //找父节点p
        //var box = document.getElementById('box');
        //找子节点h2
        var h2 = document.getElementsByTagName('h2')[0];
        
        var btn = document.getElementById('btn');
        btn.onclick = function() {
            //box.removeChild( h2 );
            h2.parentNode.removeChild( h2 );
        }
    </script>

</body>
</html>
学习ing
学习ing

全部回复(2)
过去多啦不再A梦

DOM API 就是这么设计的。

body 就是 h1 的父元素。

虽然 h1 是一个 Element,但是这个方法都是继承了 Node

Node.insertBefore()

语法

var insertedElement = parentElement.insertBefore(newElement, referenceElement);
        |                   |                       |               |
    被插入的节点             |                  被插入的节点          |
                       新插入节点的父节点                             |
                                                          插入newElement之前的那个节点               

参数和返回值

  • insertedElement 是被插入的节点,即 newElement

  • parentElement 是新插入节点的父节点

  • newElement 是被插入的节点

  • referenceElement 在插入 newElement 之前的那个节点


再看看 Node.removeChild

语法

let oldChild = node.removeChild(child);

// OR

element.removeChild(child);

参数

  • child 是要移除的那个子节点.

  • node 是 child 的父节点.

  • oldChild 保存对删除的子节点的引用. oldChild === child.

迷茫

body也是一个元素。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号