JavaScript的DOM_节点的增删改

一、概述

  DOM 不单单可以查找节点,也可以创建节点、复制节点、插入节点、删除节点和替换节点。

  

 二、write()方法

  write()方法可以把任意字符串插入到文档中去。会覆盖掉原来的html

<script type="text/javascript">
    window.onload = function () {
        document.write(‘测试write‘);                         //在网页中打印出测试write,但是原有的HTML的内容被覆盖掉了,连标题都没了  一般用于测试
        document.write(‘<br /><strong>测试write</strong>‘);    //可以解析HTML标签
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

三、createElement()方法和appendChild()方法

  1、createElement()方法可以创建一个元素节点。仅仅是创建了标签,不会自动添加到文档中,需要使用appendChild()方法添加到文档中

<script type="text/javascript">
    window.onload = function () {
       document.createElement(‘p‘);        //只是创建了一个元素节点p,还没有添加到文档中去,只是驻留在内存中
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

  2、appendChild()方法将一个新节点添加到某个节点的子节点列表的末尾上。

<script type="text/javascript">
    window.onload = function () {
       var box = document.getElementById(‘box‘);    //获取某一个元素节点
       var p = document.createElement(‘p‘);    //只是创建了一个元素节点p,还没有添加到文档中去,只是驻留在内存中
       box.appendChild(p);            //把新元素节点<p>添加id=box的div里的子节点列表的末尾上
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

四、createTextNode()方法

  createTextNode()方法创建一个文本节点。

<script type="text/javascript">
    window.onload = function () {
       var box = document.getElementById(‘box‘);//获取某一个元素节点
       var p = document.createElement(‘p‘);//只是创建了一个元素节点p,还没有添加到文档中去,只是驻留在内存中
       box.appendChild(p);//把新元素节点<p>添加id=box的div里的子节点列表的末尾上  

       var text = document.createTextNode(‘测试Div4‘);
       p.appendChild(text);  //把 文本添加到p标签里
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

五、insertBefore()方法

  insertBefore()方法可以把节点创建到指定节点的前面。

<script type="text/javascript">
    window.onload = function () {
       var box = document.getElementById(‘box‘);//获取某一个元素节点
       var p = document.createElement(‘p‘);//只是创建了一个元素节点p,还没有添加到文档中去,只是驻留在内存中

       //box.parentNode先跳到父节点,这里父节点就是body
       box.parentNode.insertBefore(p,box);//表示在id为box的元素前面添加一个p标签
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

  insertBefore()方法可以给当前元素的前面创建一个节点,但却没有提供给当前元素的后面创建一个节点。那么,我们可以用已有的知识创建一个 insertAfter()函数。

  原理是:先创建一个节点后,使用parentNode跑到父节点里将创建的节点使用appendChild添加进去

<script type="text/javascript">
    window.onload = function () {
       var box = document.getElementById(‘box‘);//获取某一个元素节点
       var p = document.createElement(‘p‘);//只是创建了一个元素节点p,还没有添加到文档中去,只是驻留在内存中
       insertAfter(p,box);
    }
    function insertAfter(newElement, targetElement) {

        var parent = targetElement.parentNode;                //得到父节点

        if (parent.lastChild === targetElement) {
            parent.appendChild(newElement);                            //如果最后一个子节点是当前元素,那么直接添加即可
        } else {
            parent.insertBefore(newElement, targetElement.nextSibling);//否则,在当前节点的下一个节点之前添加(也就是当前节点的后一个节点)
        }
    }
</script>
</head>
<body>
    <span>开始</span>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
    <span>结束</span>
</body>

六、repalceChild()方法

  replaceChild()方法可以把节点替换成指定的节点。

<script type="text/javascript">
    window.onload = function () {
       var span = document.getElementByTagName(‘span‘)[0];

       var em = document.createElement(‘em‘);

       span.parentNode.replaceChild(em,span);
    };
</script>
</head>
<body>
    <span>开始</span>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
    <span>结束</span>
</body>

七、cloneNode()方法

  cloneNode()方法可以把子节点复制出来。(复制之前先将一些空白节点删除掉)

<script type="text/javascript">
    window.onload = function(){
        var box = document.getElementById("box");
        var clone = removeWhiteNode(box).firstChild.cloneNode(true);//当这里的参数为false的时候只复制元素标签,标签中的内容不复制
        box.appendChild(clone);
    };

    function removeWhiteNode(nodes) {
        for (var i = 0; i < nodes.childNodes.length; i ++) {
            if (nodes.childNodes[i].nodeType === 3 && /^\s+$/.test(nodes.childNodes[i].nodeValue)) {
                nodes.childNodes[i].parentNode.removeChild(nodes.childNodes[i]);
            }
        }
        return nodes;
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>

八、removeChild()方法

  removeChild()方法可以把指定节点删除(同样需要将空白字符删掉在操作)

<script type="text/javascript">
    window.onload = function(){
        var box = document.getElementById("box");
        box.removeChild(removeWhiteNode(box).firstChild);    //删除box下的第一个子节点
        box.parentNode.removeChild(box);                //删除整个box(先移到box的父节点后使用删除节点的方法)
    };

    function removeWhiteNode(nodes) {
        for (var i = 0; i < nodes.childNodes.length; i ++) {
            if (nodes.childNodes[i].nodeType === 3 && /^\s+$/.test(nodes.childNodes[i].nodeValue)) {
                nodes.childNodes[i].parentNode.removeChild(nodes.childNodes[i]);
            }
        }
        return nodes;
    }
</script>
</head>
<body>
    <div id="box" class="pox" title="标题" style="color:#F00;" bbb="aaa">
        <p>测试Div1</p>
        <p>测试Div2</p>
        <p>测试Div3</p>
    </div>
</body>
时间: 2024-08-04 22:44:47

JavaScript的DOM_节点的增删改的相关文章

【JavaScript】网页节点的增删改查

一.基本概念 这部分也就是所谓的"HTML DOM",所谓HTML DOM也就是Web页面加载规则,是一个规则,也就是网页组成的基本公式. 也就是所有网页都必须按照:<html><body></body></html>--的规则编写,也按照这样的规则加载. 所谓的"网页节点",也叫"DOM节点"的通俗解释,例如html节点下的内容就是<html></html>之间所有内容,b

【转】JavaScript对Json节点的增删改

var json = { "age":24, "name":"cst" }; //修改Json中的age值,因为Json中存在age属性 json["age"] = 30; alert(json.age); //30 //增加Json中的sex值,因为Json中不存在sex属性 json["sex"] = "M"; alert(json.sex); //M <!-- 遍历Json中

【jQuery】对网页节点的增删改查

本文与<[JavaScript]网页节点的增删改查>(点击打开链接)为姊妹篇,其实JavaScript对DOM的操作已经总结了很久的,而对于jQuery对网页节点的操作,虽然一直在用,但一直没有好好总结一下,实在是不应该. 下面举同样的例子来说明这个问题: 如上图,提供3个按钮,1个下拉列表,1个输入框,提供增删改查的操作. 网页中最多10个节点,最少0个节点,多了不让加,少了不让减. 首先是本网页的基本布局: <!DOCTYPE HTML PUBLIC "-//W3C//DT

HTML DOM(二):节点的增删改查

上一篇讲述了DOM的基本知识,从其得知,在DOM眼中,HTML的每个成分都可以看作是节点(文档节点.元素节点.文本节点.属性节点.注释节点,其中,属性节点是属于元素节点),本篇的内容就是通过DOM对这些节点进行增删改查的操作. 获取(R) 1. getElementById(id).getElementsByName(name).getElementsByTagName(tagName),这三种方法都会忽略文档的结构. getElementById(id):通过id获取元素节点,如果页面上含有多

可编辑ztree节点的增删改功能图标控制---已解决

<!DOCTYPE html> <HTML> <HEAD> <TITLE> ZTREE DEMO - beforeEditName / beforeRemove / onRemove / beforeRename / onRename</TITLE> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <l

js操作DOM对象(节点的增删改)

<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>节点的增删改</title> </head> <body> <ul> <li>大家辛苦了1</li> <li>大家辛苦了2</li> <li>大家辛苦了3<

HTML DOM节点的增删改查

上篇博客中,我们已经初步接触了DOM基础,可是我们学习是为了可以更好地应用,今天我们就来看看DOM节点的增删改查. 无论在哪里,我们想要操作一个东西,总是应该先去获得它.那么我们怎么获得呢? HTML的每一个成分都能够看作是节点(文档节点.元素节点.文本节点.属性节点.凝视节点.当中,属性节点属于元素节点). W3C 提供了比較方便简单的定位节点的方法和属性,以便我们高速的对节点进行操作. 分别为:getElementById().getElementsByTagName().getElemen

JavaScript之实现基本的增删改查功能

开心一笑 听说这两天,全国都很冷.福建人说1度好冷,北京人笑了:我们这零下17度.黑龙江人也笑了:我们这零下33度.呼伦贝尔人听到哈哈大笑:我们这零下43度.福建人听完冷笑一声:我说的是室内,室内,室内 提出问题 如何利用原生的js实现基本的增删改查功能 解决问题 包含两个文件(index.jsp 和 index.js) <%@ page language="java" contentType="text/html; charset=UTF-8" pageEn

07.31《jQuery》——3.1jQuery实现DOM节点的增删改

这一小节主要讲了HTNL DOM常见的操作,包括创建节点.查找节点.插入节点.移动节点.删除节点等. 接下来上具体的代码: 代码中的注释里有上课时所整理的部分知识点: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="../jquery-3.2.1/jquery-3.2.1.js&quo