快速搞定前端JS面试 -- 第六章 JS-Web-API-DOM

3. 删除子元素

四、DOM性能

五、问题解答

1. DOM是那种数据结构?

2. DOM操作常用的API?

3. Attr和property的区别?

4. 一次性插入多个DOM节点,考虑性能

六、小结


题目

  1. DOM是那种数据结构?

  2. DOM操作常用的API?

  3. Attr和property的区别?

  4. 一次性插入多个DOM节点,考虑性能

知识点

  1. DOM的本质

  2. DOM节点操作

  3. DOM结构操作

  4. DOM性能

一、DOM的本质


Xml是一种可扩展的标记语言,可以描述任何一种结构的数据

Html是一种特定的xml,结构和xml相同,但规定了标签的名称规范

DOM的本质是从html解析出来的一棵树

dom 演示

一段文字 1

一段文字 2

一段文字 3

    二、DOM节点操作


    1.获取DOM节点

    2. Property

    3. Attribute

    const div1 = document.getElementById(‘div1’)

    console.log(‘div1’, div1)

    const divList = document.getElementsByTagName(‘div’) // 集合

    console.log(‘divList.length’, divList.length)   // 2

    console.log(‘divList[1]’, divList[1])     // 第二个div

    const containerList = document.getElementsByClassName(‘container’) // 集合

    console.log(‘containerList.length’, containerList.length)   // 2

    console.log(‘containerList[1]’, containerList[1])    // 第二个div

    const pList = document.querySelectorAll(‘p’)    // css选择器

    console.log(‘pList’, pList)

    const pList = document.querySelectorAll(‘p’)

    const p1 = pList[0]

    // property 形式,修改JS变量的属性,不会对标签产生影响

    p1.style.width = ‘100px’

    console.log( p1.style.width )     // 获取样式:100px

    p1.className = ‘red’

    console.log( p1.className )     // 获取className:red

    console.log(p1.nodeName)     // p

    console.log(p1.nodeType)     // 1类型

    // attribute形式,修改了标签的属性

    p1.setAttribute(‘data-name’, ‘imooc’)

    console.log( p1.getAttribute(‘data-name’) )

    p1.setAttribute(‘style’, ‘font-size: 50px;’)

    console.log( p1.getAttribute(‘style’) )

    Property和attribute

    Property:修改对象属性,不会体现到html结构中

    Attribute:修改html属性,会改变html结构

    两者都有可能引起DOM重新渲染

    (使用建议:尽量用property操作,如果必须要改变标签结构时使用attribute)

    一些常用的 HTML DOM 方法

    getElementById(id) - 获取带有指定 id 的节点(元素)

    appendChild(node) - 插入新的子节点(元素)

    removeChild(node) - 删除子节点(元素)

    一些常用的 HTML DOM 属性:

    innerHTML - 节点(元素)的文本值

    parentNode - 节点(元素)的父节点

    childNodes - 节点(元素)的子节点

    attributes - 节点(元素)的属性节点

    三、DOM结构操作


    1. 新增/插入节点

    2. 获取子元素列表,获取父元素

    3. 删除子元素

    const div1 = document.getElementById(‘div1’)

    const div2 = document.getElementById(‘div2’)

    // 新建节点

    const newP = document.createElement(‘p’)

    newP.innerHTML = ‘this is newP’

    // 插入节点

    div1.appendChild(newP)

    // 移动节点

    const p1 = document.getElementById(‘p1’)

    div2.appendChild(p1)   // p1被移动到div2里

    // 获取父元素

    console.log( p1.parentNode )    // div2

    // 获取子元素列表

    const div1ChildNodes = div1.childNodes

    console.log( div1.childNodes )      // 7(包含4 text和3 p)

    const div1ChildNodesP = Array.prototype.slice.call(div1.childNodes).filter(child => {

    if (child.nodeType === 1) {    // 判断是否是

    的DOM节点

    return true

    }

    return false

    })

    console.log(‘div1ChildNodesP’, div1ChildNodesP)

    // 删除节点

    div1.removeChild( div1ChildNodesP[0] )

    方法

    描述

    getElementById()

    返回带有指定 ID 的元素。

    getElementsByTagName()

    返回包含带有指定标签名称的所有元素的节点列表(集合/节点数组)。

    getElementsByClassName()

    返回包含带有指定类名的所有元素的节点列表。

    appendChild()

    把新的子节点添加到指定节点。

    removeChild()

    删除子节点。

    replaceChild()

    替换子节点。

    insertBefore()

    在指定的子节点前面插入新的子节点。

    createAttribute()

    创建属性节点。

    createElement()

    创建元素节点。

    createTextNode()

    创建文本节点。

    getAttribute()

    返回指定的属性值。

    setAttribute()

    把指定属性设置或修改为指定的值。

    四、DOM性能


    DOM操作非常‘昂贵’(占用CPU,可能会造成浏览器重排,耗时),因此尽量避免频繁的DOM操作;

    对DOM查询做缓存(减少DOM操作);

    将频繁操作改为一次性操作;

    1. DOM查询做缓存

    2. 将频繁操作改为一次性操作

    自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

    深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

    因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

    img

    既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

    由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

    如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

    最后

    分享一套阿里大牛整理的前端资料给大家,点击前端校招面试题精编解析大全即可免费下载

    ❤️ 谢谢支持,喜欢的话别忘了 关注、点赞哦。

    资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!**

    [外链图片转存中…(img-meBUQ5Lv-1713805835037)]

    由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

    如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

    [外链图片转存中…(img-HrOXbIa9-1713805835038)]

    最后

    分享一套阿里大牛整理的前端资料给大家,点击前端校招面试题精编解析大全即可免费下载

    ❤️ 谢谢支持,喜欢的话别忘了 关注、点赞哦。

    前端校招面试题精编解析大全

    • 3
      点赞
    • 4
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值