登录
首页 >  文章 >  前端

NodeList 和 HTMLCollection :实时集合和静态集合

来源:dev.to

时间:2024-11-05 14:10:10 248浏览 收藏

对于一个文章开发者来说,牢固扎实的基础是十分重要的,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)
    
    

    输出 :

    NodeList 和 HTMLCollection :实时集合和静态集合


    当对底层文档进行更改时,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删除
    相关阅读
    更多>
    最新阅读
    更多>
    课程推荐
    更多>