一、什么是DOM

  JavaScript由ECMAScript、DOM和BOM三部分组成,其中DOM代表描述网页内容的方法和接口,即文档对象模型(Document Object Model)。在网页上,组织页面(或文档)的对象被组织在一个树形结构中,用来表示文档中对象的标准模型就称为DOM,而树形结构就是我们常说的DOM树。

  维基百科中介绍DOM更为准确:DOM是一种跨平台和语言非依赖性的应用程序编程接口,即处理现在的HTML,XHTML或XML文档作为树结构,其中每个节点是一个对象,每个节点表示该文档的一部分。

二、DOM节点

1.节点的类型

  DOM树是由许多不同类型的节点组成的,而这些节点类型都有一个nodeType值,我们可以通过nodeType值来判断我们获取的或想要的是不是对应类型的节点。

节点类型 元素节点(标签节点) 属性节点 文本节点(空格、换行、文字) 注释节点 document节点
nodeType值 1 2 3 8 9

  除了通过nodeType值判断类型以外我们还可以通过nodeName来查看元素节点和属性节点的节点名称,还有使用nadeValue来查看属性节点的属性值。

2.获取元素节点

document.getElementById(id);
document.getElementByTagName(tagname);
document.getElementByClassName(classname);

  通常想要在JavaScript中更改或使用HML中的元素节点时,都要先获取才可以调用,那么我们就是通过设置元素的Id属性或Class属性来获取,或是使用标签名获取。但是要注意的是getElementById()方法不能工作在XML中,在XML文档中,必须通过拥有id属性来进行搜索,而此类型必须在 XML DTD 中进行声明。

  获取完我们想要的节点后,我们还可以通过节点的关系来操作其他节点,这里我们以div元素为初设元素节点来举例。

  2.1 子节点

div.children();
div.childNodes();

  获取div下面的子节点,而div.children()只能获取到是元素节点的子节点,而div.childNodes()会获取所有类型的子节点,也就是说会解析空白文本节点。

  2.2 父节点

div.parentNode();
div.offsetParent();

  获取div的父节点,div.offsetParent()获取的是具有定位属性的祖先节点,即从父节点开始查找,如果父节点没有定位属性,那么再找父节点的父节点,直到找到有定位属性的节点。

  2.3 兄弟节点

//下一个兄弟节点
div.nextElementSibling();
div.nextSibling();
//上一个兄弟节点
div.previousElementSibling();
div.previousSibling();

  这里有没有Element很关键,跟获取子节点一样,div.nextSibling()和div.previousSibling()会解析空白节点,会获取到div下面的空格或回车。

  2.4 首尾子节点

//获取div的第一个子节点
div.firstElementChild();
div.firstChild();
//获取div的最后一个子节点
div.lastElementChild();
div.lastElementChild();

  区别同上。

3.节点操作

  我们除了可以在HTML中添加、删除个修改节点,也可以在JavaScript中对节点进行操作。

  3.1 创建节点

//创建节点/创建文本节点
createElement();
createTextNode();

  创建文本节点一般用来向元素节点中添加内容,它创建的是静态文本,不能像innerHTML一样带有HTML格式,所以creatTextNode()更安全,而innerText又有浏览器兼容问题。

  3.2 添加节点

  我们创建的节点不会自动添加到HTML里,需要我们对创建的节点进行操作。

//向尾部添加子节点
appendChild();
//向目标节点之前添加
insertBefore(newElement,targetElement);

  insertBefore()第二个参数是可选参数,如果不写第二个参数那么就默认向尾部添加,即等同于appendChild();

  3.3 替换

//将旧节点换为新节点
replaceChild(newElement,oldElement);

  div.replaceChild(newElement,oldElement) ,这里无论是新节点还是旧节点,都必须是div的子节点。

  3.4 删除

removeChild();

  注意删除的是子节点。

  3.5 克隆/复制

//深复制或浅复制
cloneNode(boolean);

  当参数的布尔值为true时为深复制,即会复制节点本身以及它以下的所有子节点。

  当参数的布尔值为false时为浅复制,只会复制节点自己本身。

  3.6 判断

hasChildNode();

  判断是否有子节点,返回布尔值。

  3.7 属性

//获取节点属性
getAttribute();
//设置节点属性
setAttribute();
//删除节点属性
removeAttribute();

 要注意的一点就是class属性不能通过setAttribute(); 设置。

三、DOM的优缺点

  DOM的优点主要表现在:易用性强,并且遍历简单,支持XPath,增强了易用性。
  DOM的缺点主要表现在:效率低,解析速度慢,内存占用量过高。

  


JavaScript中的DOM及相关操作的更多相关文章

  1. Javascript中日期函数的相关操作

    Date对象具有多种构造函数,下面简单列举如下: new Date() new Date(milliseconds) new Date(datestring) new Date(year, month ...

  2. 借助JavaScript中的Dom属性改变Html中Table边框的颜色

    借助JavaScript中的Dom属性改变Html中Table边框的颜色 -------------------- <html> <head> <title>我是页 ...

  3. grails项目中(DB的相关操作)

    grails项目中(DB的相关操作) save:保存Domain对象的数据到对应的库表中(可能是insert也可能是update) findBy: 动态方法,查找并返回第一条记录,方法名可以变化 eg ...

  4. javascript中获取dom元素的高度和宽度

    javascript中获取dom元素高度和宽度的方法如下: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网 ...

  5. javascript中获取dom元素高度和宽度

    javascript中获取dom元素高度和宽度的方法如下: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网 ...

  6. js | javascript中获取dom元素的高度和宽度

    javascript中获取dom元素高度和宽度的方法如下: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网 ...

  7. 一些JavaScript中的DOM的优化小技巧

    在进行DOM优化时需要关注的问题有:修改DOM的时候,会引起页面的重排,重绘.因为JS是单线程执行的,那么在重排重绘的过程中可能会阻塞用户的操作.为了更好的用户体验,必须要严格控制这些操作. 一.对象 ...

  8. javascript中的DOM介绍(一)

    一.基础知识点 1.DOM是文档对象模型,是针对HTML和XML文档的一个API(应用程序接口) 2.DOM描绘了一个层次化的节点数,允许开发人员进行添加,移除个修改等操作 3.IE浏览器中所有的DO ...

  9. JavaScript中forEach的用法相关

    首先说下JavaScript的forEach的标准格式. 为数组中的每个元素执行指定操作. array1.forEach(callbackfn[, thisArg]) 参数 定义 array1 必需. ...

随机推荐

  1. Dart基础-泛型和库

    https://blog.csdn.net/hekaiyou/article/details/46774727

  2. 【mysql】group_concat函数substring_index函数

    1.group_concat函数:用于将多个字符串连接成一个字符串 用法规则: SELECT GROUP_CONCAT(拼接的字段) from tableName; 使用:查询basic_projec ...

  3. iOS UIAlertController在iPhone与iPad上的区别

    很简单的一段代码: // 首先声明一个UIAlertController对象 private var alertController: UIAlertController! // 初始化UIAlert ...

  4. HTTP的简单的解析

    HTTP 中文全称为超文本传输协议是一种为分布式,合作式,多媒体信息系统服务,面向应用层的协议.它是一种通用的,不分状态(stateless)的协议,除了诸如名称服务和分布对象管理系统之类的超文本用途 ...

  5. Progressive Scramble【模拟】

    问题 J: Progressive Scramble 时间限制: 1 Sec  内存限制: 128 MB 提交: 108  解决: 45 [提交] [状态] [命题人:admin] 题目描述 You ...

  6. CSS基础【1】:体验CSS

    CSS起源 web的衰落:在 web 早期(1990-1993),html是一个很局限的语言.几乎完全由用于描述段落,超链接,列表和标题的结构化元素组成.随着万维网的出现(用户交互体验的加强),对 h ...

  7. 【Visual Studio 扩展工具】使用 ComponentOne迷你图控件,进行可视化数据趋势分析

    概述 迷你图 —— Sparklines是迷你的轻量级图表,有助于快速可视化数据. 它们是由数据可视化传奇人物Edward Tufte发明的,他将其描述为“数据密集,设计简单,字节大小的图形.”虽然迷 ...

  8. 组合,多态与多态性,封装以及property装饰器介绍

    一:组合: 什么是组合:组合指的是某一个对象拥有一个属性,该属性的值是另外一个类的对象. 为何要用组合:通过为某一个对象添加属性(属性的值是另外一个类的对象)的方式,可以间接地将两个类关联/整合/组合 ...

  9. EPEL源-是什么全称

    EPEL源   EPEL (Extra Packages for Enterprise Linux)是基于Fedora的一个项目,为“红帽系”的操作系统提供额外的软件包,适用于RHEL.CentOS和 ...

  10. 二叉树分派硬币 Distribute Coins in Binary Tree

    2019-03-27 15:53:38 问题描述: 问题求解: 很有意思的题目.充分体现了二叉树的自底向上的递归思路. 自底向上进行运算,对于最底层的二叉子树,我们需要计算每个节点向其parent传送 ...