登录
首页 >  文章 >  前端

NodeList 与 HTMLCollection:实时集合和静态集合之间的区别

来源:dev.to

时间:2024-12-08 20:48:41 177浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习文章相关编程知识。下面本篇文章就来带大家聊聊《NodeList 与 HTMLCollection:实时集合和静态集合之间的区别》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!

我们将详细研究nodelisthtmlcollection以及nodelist和htmlcollection。

首先,两者都有一个 length 属性,返回列表(集合)中的元素数量。


1.html集合

html dom 中的

htmlcollection 已上线; getelementsbyclassname()getelementsbytagname() 返回一个实时 htmlcollection ,表示具有所有给定 类名称的所有子元素的类似数组的对象.

示例 :




    
    
    nodelist and htmlcollection


      
  • item-1
  • item-2
  • item-3
  • item-4
  • item-5
  • item-6
  • item-7
  • item-8
  • item-9
  • item-10
  • item-11
  • item-12
const selected = document.getelementsbyclassname("items")
console.log(selected)

输出 :

NodeList 与 HTMLCollection:实时集合和静态集合之间的区别


当底层文档更改时,htmlcollection 会自动更新

让我们写一个示例 :




    
    
    nodelist and htmlcollection


    
dev community

dev community sonay kara

dev community sonay kara
const selected = document.getelementsbyclassname("card")
console.log(selected)
selected[0].innerhtml += `
  • dev.to
  • `; console.log(selected)

    输出 :

    NodeList 与 HTMLCollection:实时集合和静态集合之间的区别

    从输出中可以看出,当将新的 html 标签添加到具有卡片类的元素时,htmlcollection 会更新因为它是活动的


    2. 节点列表

    queryselectorall() 返回一个 static (非实时) nodelist 表示与指定组匹配的文档元素列表选择器。但是 childnodes 返回一个 live nodelist

    示例 :

    
    
    
        
        
        nodelist and htmlcollection
    
    
          
    • item-1
    • item-2
    • item-3
    • item-4
    • item-5
    • item-6
    • item-7
    • item-8
    • item-9
    • item-10
    • item-11
    • item-12
    const selected = document.queryselectorall(".items")
    console.log(selected)
    
    

    输出 :

    image description


    当对底层文档进行更改时,queryselectorall() 返回的 nodelist 不会自动更新,因为 它是非活动的

    让我们写一个示例 :

    
    
    
        
        
        nodelist and htmlcollection
    
    
        
    dev community

    dev community sonay kara

    dev community sonay kara
    const selected = document.queryselectorall(".card")
    selected[0].innerhtml += `
  • dev.to
  • `; console.log(selected)

    输出 :

    • 浏览器

    NodeList 与 HTMLCollection:实时集合和静态集合之间的区别

    • 控制台

    NodeList 与 HTMLCollection:实时集合和静态集合之间的区别

    从输出中可以看出,当将新的 html 标签添加到具有卡片类的元素时,浏览器会更新,但 nodelist 不会更新,因为 nodelist 不活动.


    当底层文档发生更改时,childnodes 返回的 nodelist 会自动更新,因为它是活动的

    示例 :

    
    
    
        
        
        nodelist and htmlcollection
    
    
        
    dev community

    dev community sonay kara

    dev community sonay kara
    const selected = document.querySelector(".card")
    selected.innerHTML += `
  • dev.to
  • `; console.log(selected.childNodes)

    输出 :

    NodeList 与 HTMLCollection:实时集合和静态集合之间的区别

    从输出中可以看出,当一个新的 html 标签添加到具有卡片类的元素时,nodelist 会更新因为它是活动的


    结论

    总之,htmlcollection 始终是一个实时集合。 nodelist 通常是静态集合。

    我们检查了 nodelisthtmlcollection 是什么。现在您知道什么是 nodelist 和 htmlcollection 了。

    好了,本文到此结束,带大家了解了《NodeList 与 HTMLCollection:实时集合和静态集合之间的区别》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

    声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>