JavaScript之DOM操作(下集)

Posted 精通各种hello world的小希

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript之DOM操作(下集)相关的知识,希望对你有一定的参考价值。

节点操作

dom节点操作可以归纳为增删改查,查的操作直接获取该节点,然后在控制台打印,如果有同学不会的话可以看看上集。

操作步骤注意事项
创建节点()

1.let xx=document.createElement('div')  //新建节点

2.父节点.appendChild(子节点)  //节点上树

新建的节点并没有挂载到DOM树上,必须要通过appendChild()方法追加到树上

移动节点()新父节点.appendChild(已有的父节点)
删除节点()父节点.removeChild(要删除子结点);

代码

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
    </style>
</head>

<body>
    <h2>优秀的程序员</h2>
    <div id="div1">
        <p id="p1">优秀的程序员必备三件套</p>
        <ul id='ul1'>
            <li>秃头</li>
            <li>格子衫</li>
            <li>拖鞋</li>
        </ul>
    </div>
</body>
<script>
    // 获取节点
    let div1 = document.getElementById('div1')
    // 新增节点
    const div2 = document.createElement('div')
    // 节点上树
    div1.appendChild(div2)
    // 追加样式
    div2.style.width = '200px'
    div2.style.height = '100px'
    div2.style.border = 'solid 1px red'
    // ________________________________________
    // 移动节点
    const ul1 = document.getElementById('ul1')
    div2.appendChild(ul1);
     // ________________________________________
    // 删除节点
    const p1 = document.getElementById('p1')
    div1.removeChild(p1)
</script>

</html>

打印结果

结果1:在id=‘div1’的标签内部增加一个div标签,并追加样式

 结果2:把ul标签移动到div2内部

 结果3:删除div1内部的p标签

节点类型

我们先打印一下ul1这个父节点

// 获取节点
    let ul1 = document.getElementById('ul1')
    console.log(ul1.childNodes)

大家肯定会带着两个疑惑:

1.text是啥?

2.明明在li标签前面没有写任何的文本,为什么会有text这玩意?

疑惑解答

DOM规定文档中的每个成分都是一个节点(Node),DOM节点有:

类型功能
元素节点(Element)其实就是标签,例如<p>、<div>、<ul>
文本节点(Text)你能在浏览器页面中看见的东西,比如:上述页面中‘优秀的程序员’
属性节点(Attr)元素属性,比如<a>标签的链接属性href="*"。

属性节点在这里先不讲,所以text就是文本节点,就是我们在浏览器中所能看见的东西,但是为什么li标签外面也有文本节点呢?我放一张图给大家看就知道了!

 没错,那堆空格也算是文本!所以把那堆空格删除了,ChildNodes就只剩下li标签。

 

在这里介绍给大家两个判断DOM节点的属性:nodeName和nodeType。

属性功能
nodeType

nodeType = 1  //元素节点

nodeType = 3  //文本节点

nodeType = 8  //注释节点

nodeType = 9  //document节点

nodeType = 10 //DTD节点

nodeName

元素节点返回元素名称

文本节点返回 #text

 大家可以根据DOM的节点属性,封装一个API去筛选出元素节点。

DOM性能

为什么要讲性能这块呢,因为dom操作就像香港的土地,寸土寸金,是非常“昂贵的”,dom操作有可能会导致浏览器重新渲染,而且占用的cpu也比较多,如果频繁操作会导致卡顿等问题。

比如我们想要在div标签里面插入十个p标签,通常我们都会这样做:

<body>
    <div id="div1"></div>
</body>
<script>
    const div1 = document.getElementById('div1');
    for (let i = 0; i < 10; i++) 
        const p1 = document.createElement('p');
        p1.innerHTML = `this is p$i`;
        div1.appendChild(p1);
    
</script>

打印结果如下:

的确,我们可以把想要的结果打印出来,但是这个代码段的性能太差了,每一次让子结点上树和追加文本都会进行dom渲染一次,加大CPU的负担(好比我叫你拿十本书上五楼,你非得要一次拿一本上来,那会不会有亿点点累?)

那我们有什么方法优化呢?没错!既然我们分十次拿十本书,为什么我们不能一次性都拿上五楼?所以同样的解决方法,我们不在循环里面操作,把每次插入这个操作打包成一个整体,一块插进去就好了。

const div1 = document.getElementById('div1');
const bag = document.createDocumentFragment()
for (let i = 0; i < 10; i++) 
    const p1 = document.createElement('p');
    p1.innerHTML = `this is p$i`;
    bag.appendChild(p1);

div1.appendChild(bag);

执行步骤

1.获取div1标签,通过createDocumentFragment()创建一个文件片段(把十本书拿上五楼之前准备一个书包)

2.for循环里面在bag中插入新的‘p’结点(就是把那十本书一本一本地放进书包)

3.把bag文件片段插入到div1中(把书包拿上五楼之后给我)


创作不易,路过的朋友可以动一下您的发财小手点个赞吗?码完字干饭去!

今天你学废了吗?

 

以上是关于JavaScript之DOM操作(下集)的主要内容,如果未能解决你的问题,请参考以下文章

微服务专题之.Net6下集成消息队列-RabbitMQ交换机模式代码演示(全)

第十五篇:JavaScript 之 Dom操作

JavaScript之DOM树

JavaScript基础之DOM修改样式

10-JavaScript之DOM的事件操作

更改页面javascript代码(TamperMonkey)以将键盘笔触发送到父DOM