热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

JavascriptDom元素获取和添加详解

这篇文章主要介绍了JavascriptDom元素获取和添加详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1.Dom元素的获取

  • document.getElementById():通过id获取一个Dom元素
  • document.getElementsByClassName():通过class名字获取一个或多个Dom元素(伪数组)
  • document.getElementsByTagName():通过标签名字获取一个或多个Dom元素(伪数组)
  • document.querySelector():获取指定 CSS 选择器的一个元素
  • document.querySelectorAll():获取指定 CSS 选择器的多个元素(伪数组)

ES6选择器与其他选中器的区别:

document.getElementsByTagName()和document.getElementsByClassName()获取到的都是动态列表

document.querySelectorAll()获取到的是静态列表,Dom结构发生变化要重新获取,不然会出问题



  
    
    
  
  
  
    
  • 1
  • 2
  • 3
  • 4

document.getElementsByTagName()和document.getElementsByClassName()获取到的是 HTMLCollection,不能使用foreach()遍历

document.querySelectorAll()获取到的NodeList,可以使用foreach()遍历



  
    
    
    
  
  
    
  • 1
  • 2
  • 3
  • 4

2.Dom元素节点类型

Dom节点类型分3类:元素节点,属性节点,文本节点

每种节点都有3种属性 nodeName,nodeType,nodeValue



  
    
    
  
  
  
    
我是谁

3.获取Dom元素的子元素,父元素,兄弟元素

通过children属性可以获取当前Dom元素的子元素



  
    
    
  
  
  
    
  • 1
  • 2
  • 3

获取当前元素的父元素

parentElement/parentNode这两个属性都可以



  
    
    
  
  
  
    
  • 1
  • 2
  • 3

获取当前元素的兄弟元素

previousElementSibling属性:上一个兄弟元素

nextElementSibling属性:下一个兄弟元素



  
    
    
  
  
  
    
  • 1
  • 2
  • 3

注意:

children与childNodes,前者只包含元素节点,而后者为元素节点+文本节点(回车换行也算是文本节点)

而previousElementSibling与previousSibling,nextElementSibling与nextSibling也一个道理

firstChild和lastChild:firstChild等价于childNodes[0],lastChild相当于childNodes的最后一个元素

4.DOM元素的添加与移除

添加子元素

appendChild():将目标元素作为子元素添加到当前元素的最后面

insertBefore():将目标元素作为子元素添加到当前元素中,位置可以自由选择



  
    
    
  
  
  
    
  • 1
  • 2
  • 3

运行结果

  • 1
  • life
  • 2
  • 3
  • 4

删除子元素和替换子元素

removeChild():删除子元素

replaceChild():替换子元素

语法:parent.removeChild(child)

语法:parent.removeChild(替换的元素, 被替换的元素)



  
    
    
  
  
  
    
  • 1
  • 2
  • 3

运行结果:

  • 1
  • replace li tag

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • Python 内存管理机制详解
    本文深入探讨了Python的内存管理机制,涵盖了垃圾回收、引用计数和内存池机制。通过具体示例和专业解释,帮助读者理解Python如何高效地管理和释放内存资源。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 本文详细介绍如何使用CSS自定义HTML5视频播放器的样式,涵盖常见属性及跨浏览器兼容性问题。发布时间:2020-09-14 14:46:29;来源:亿速云;阅读量:58;作者:小新。 ... [详细]
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 如何清除Chrome浏览器地址栏的特定历史记录
    在使用Chrome浏览器时,你可能会发现地址栏保存了大量浏览记录。有时你可能希望删除某些特定的历史记录而不影响其他数据。本文将详细介绍如何单独删除地址栏中的特定记录以及批量清除所有历史记录的方法。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 本文探讨了在构建应用程序时,如何对不同类型的数据进行结构化设计。主要分为三类:全局配置、用户个人设置和用户关系链。每种类型的数据都有其独特的用途和应用场景,合理规划这些数据结构有助于提升用户体验和系统的可维护性。 ... [详细]
  • Linux中的yum安装软件
    yum俗称大黄狗作用:解决安装软件包的依赖关系当安装依赖关系的软件包时,会将依赖的软件包一起安装。本地yum:需要yum源,光驱挂载。yum源:(刚开始查看yum源中的内容就是上图 ... [详细]
  • 鼠标悬停出现提示信息怎么做
    概述–提示:指启示,提起注意或给予提醒和解释。在excel中会经常用到给某个格子增加提醒信息,比如金额提示输入数值或最大长度值等等。设置方式也有多种,简单的,仅为单元格插入批注就可 ... [详细]
  • 精致小屏灰色风格苹果CMS v10模板,支持DIY主题管理系统
    探索一款专为影视站设计的苹果CMS v10模板,具备强大的主题管理系统和500多个设置项,无需二次开发即可轻松配置。下载地址:https://www.mytheme.cn/maccms/244.html,演示地址:http://demo.mytheme.cn/index.php?id=244。 ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 气象对比分析
    本文探讨了不同地区和时间段的天气模式,通过详细的图表和数据分析,揭示了气候变化的趋势及其对环境和社会的影响。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • 在使用 Vue CLI 创建的项目中,引入样式模块(CSS Module)后,发现类名被自动修改。本文将详细解释这一现象并提供解决方案。 ... [详细]
author-avatar
希望全家人都幸福_870
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有