DOM基础知识(Node对象、Element对象)
5、Node对象
u 遍历节点
u 父节点
.parentNode - 获取父节点—> 元素节点或文档节点
.parentElement - 获取父元素节点—> 元素节点
u 子节点
.childNodes – 获取所有子节点;
.firstChild – 获取第一个子节点; .lastChild – 获取最后一个子节点
u 兄弟节点
.previousSibling - 上一个兄弟节点; .nextSibling - 下一个兄弟节点
L 空白节点问题:

概念:空白节点,实际上就是一个空的文本节点
原因: 编写HTML代码时,输入换行符,浏览器解析HTML页面为DOM结构时,自动添加空白节点 ---获取子节点及兄弟节点的属性不能正常使用
注:IE8及以下版本的浏览器不存在空白节点问题
- 解决方案
1. 弃用获取子节点和兄弟节点的属性;改用getElementsByTagName( ) 方法
从父级根据标签名得到所有子级,选[0]; 自动把空白节点去掉
- 使用原本的子节点属性,人为进行判断,进行重构
- 封装方法:

l 插入节点
父.appendChild(子)
作用:将child节点插入到parent父节点的子节点列表的最后面
父.insertBefore(new子,current子)
作用:将newChild插入到parent父节点下currentChild子节点的前面
注意 - 没有insertAfter( )方法
- 自定义---- insertAfter(newChild, currentChild) 方法

function insertAfter(parent, newChild, currentChild){
var next = currentChild.nextSibling;
if(next.nodeType == 3){
next = next.nextSibling;
}
Parent.insertBefore(newChild,next);}
如果调用该方法时,目标节点为 null 值或不存在的话;等价于调用 appendChild( ) 方法
}
l 删除节点 – 父.removeChild(子)
l 替换节点 –父.replaceChild(newChild,oldChild)
newChild - 创建新的,从页面获取; parent和oldChild之间必须是父子关系
u 复制节点 - .cloneNode(boolean)
boolean类型的参数:是否复制后代节点 true:表示赋值; false:(默认值)表示不复制
* 返回值 - 表示被复制新的节点
注:如果复制的节点具有id属性的话,在复制完成之后,修改id属性值
6、Element对象
u 概念:

* 使用<节点>概念解析HTML
被解析为元素节点、属性节点和文本节点;三者相互独立(文本、元素节点是父子关系)
* 使用<元素>概念解析HTML
被解析为元素,属性和文本是元素的一部分
注:元素节点和元素都代表HTML页面中的标签
DOM查询的六个方法返回的既是元素节点(Node对象),又是元素(Element对象)
u 遍历元素
² 获取父元素
.parentElement
² 获取子元素
.children 获取所有子元素的集合
.firstElementChild获取第一个子元素 .lastElementChild获取最后一个子元素
² 获取兄弟元素
.previousElementSibling 获取指定节点的前一个兄弟节点。
.nextElementSibling 获取指定节点的后一个兄弟节点。
注:所有获取子元素和兄弟元素的属性,在 IE8及以下版本的浏览器不支持
* 人为提供浏览器的兼容解决方案
u 操作属性
² 获取属性 .getAttribute(属性名)
如果获取的属性名根本不存在,结果为null
如果属性名存在,返回属性的值,转换为boolean值 true
如果属性名不存在,返回null,转换为boolean值 false
² 设置属性 .setAttribute(属性名, 属性值)
如果属性名已存在的话 - 修改指定属性名的值
如果属性名不存在的话 - 新增属性(同时设置属性名和属性值) */
² 删除属性 .removeAttribute(属性名)
效果: 将属性名和属性值一并删除
² 判断是否含有属性 .hasAttribute(属性名) 有----true; 没有----false
* hasAttribute( )方法:
属于Element对象; 作用:判断指定标签是否含有【指定属性】
* hasAttributes( )方法:
属于Node对象;作用:判断指定标签是否包含属性
l 文本操作
- Ø 通过Node 对象的节点方式进行操作
* 文本节点一定是元素节点的子节点 - 获取指定的文本节点
* 通过 nodeValue 属性可以获取或设置文本节点的文本内容
利用 Node 方式操作文本(文本节点)
* 通过获取子节点的方式得到文本节点
* 通过 appendChild() 方法添加文本节点
* 通过 removeChild() 方法删除文本节点
文本节点的节点图

文本节点具有 nodeName、nodeType和nodeValue
nodeType - 用于判断当前是否是文本节点(3)
nodeValue - 用于获取或设置文本节点的文本内
【当元素节点的子节点为文本节点时; 不存在空白节点的问题】
- Ø textContent 属性
作用:获取指定元素中所有的文本内容(包含所有后代节点的文本内容);
【注:不支持IE8及以下版本;结果不报错,为 undefined 转换为boolean类型 false】
- innerText属性
【支持IE8及以下版本浏览器[专有]属性; IE9以上及其他(Chrome和火狐)新版本都兼容
获取文本的兼容问题
function getText(elem){
var text;
if(elem.textContent){
text = elem.textContent;
}else{
text = elem.innerText;
}
return text;
}
- innerHTML属性
作用:获取或设置指定标签的所有HTML代码[有什么输出什么]
注意:使用innerHTML属性的安全性很低(可能接收一些恶意代码)
解决:使用innerHTML属性时,对应的值不能是用户输入内容
DOM基础知识(Node对象、Element对象)的更多相关文章
- HTML DOM基础知识
HTML DOM基础知识 一.什么是DOM? 1.HTML DOM 定义了访问和操作HTML文档的标准方法. 2.HTML DOM 把 HTML 文档呈现为带有元素.属性和文本的树结构(节点树). 3 ...
- C/C++基础知识总结——类与对象
1. 面向对象程序设计的特点 1.1 抽象 1.2 封装 1.3 继承 1.4 多态 (1) 分为:强制多态.重载多态.类型参数化多态.包含多态 (2) 强制多态:类型转换 重载多态: 类型参数化多态 ...
- JAVA核心技术I---JAVA基础知识(不可变对象和字符串)
一:不可变对象 不可变对象(Immutable Object) –一旦创建,这个对象(状态/值)不能被更改了–其内在的成员变量的值就不能修改了. –典型的不可变对象 • 八个基本型别的包装类的对象 • ...
- Js基础知识2-对象、对象属性全解
Object对象 Object对象包含如下属性和方法,也就意味着一切对象(函数也是对象)都包含如下方法. 每种方法和属性在不同的对象中有不同的作用,并不是每种对象都有使用每个方法的必要. 下面是Obj ...
- DOM基础知识(概念、节点树、事件、Document)
1. DOM概念 全称为 Document Object Model,译为文档对象模型 D:文档 - DOM将HTML页面解析为一个文档 —> document对象 O:对象 - DOM将H ...
- DOM中的node与element的区别
先看document的两个常见method. document.createTextNode Constructor: Text document.createElement Constructor: ...
- 工作随笔—Java容器基础知识分享(持有对象)
1. 概述 通常,程序总是运行时才知道的根据某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型,为解决这个普遍的编程问题:需要在任意时刻和任意位置创建任意数量的对象,所以,就 ...
- java 基础知识九 类与对象
java 基础知识九 类与对象 1.OO(Object–Oriented )面向对象,OO方法(Object-Oriented Method,面向对象方法,面向对象的方法)是一种把面向对象的思想应 ...
- 《Java基础知识》Java多态对象的类型转换
这里所说的对象类型转换,是指存在继承关系的对象,不是任意类型的对象.当对不存在继承关系的对象进行强制类型转换时,java 运行时将抛出 java.lang.ClassCastException 异常. ...
随机推荐
- Spring 获取propertise文件中的值
Spring 获取propertise文件中的值 Spring 获取propertise的方式,除了之前的博文提到的使用@value的注解注入之外,还可以通过编码的方式获取,这里主要说的是要使用Emb ...
- java加密解密算法位运算
一.实例说明 本实例通过位运算的异或运算符 “ ^ ” 把字符串与一个指定的值进行异或运算,从而改变每个字符串中字符的值,这样就可以得到一个加密后的字符串.当把加密后的字符串作为程序输入内容,异或运算 ...
- sql 查询多列 小于某值
select COUNT(*) from ( select ID,H1 AS Value from Table_1 union all select ID,H2 from Table_1 union ...
- vc++如何创建程序01
1 .选择文件+新建(ctrl+N),然后选择一个空的工程,完成 2 然后在选择file新建,在files文件下面选择一个C++Source File,并取个文件名(比如为point可以不带.c) 我 ...
- hibernate详细配置
映射配置 <!-- 映射文件: 映射一个实体类对象: 描述一个对象最终实现可以直接保存对象数据到数据库中. --> <!-- package: 要映射的对象所在的包(可选,如果不 ...
- BZOJ 1305: [CQOI2009]dance跳舞 网络最大流_二分答案_建模
Description 一次舞会有n个男孩和n个女孩.每首曲子开始时,所有男孩和女孩恰好配成n对跳交谊舞.每个男孩都不会和同一个女孩跳两首(或更多)舞曲.有一些男孩女孩相互喜欢,而其他相互不喜欢(不会 ...
- Zookeeper 使用
转自:https://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/ 安装和配置详解 本文介绍的 Zookeeper 是以 3.2. ...
- node+express框架中连接使用mysql经验总结
最近在学习node.js,做了一个练手项目,使用node.js+express框架,配合mysql数据库和前端vue框架开发一个多人文档编辑系统. koa,express,node 通用方法连接MyS ...
- 小松之LINUX 驱动学习笔记(二)
这两天一直在看字符驱动那块,后来从网上找啦几个例子,自己编译啦下,安装啥的都挺正常,就是用测试程序测试的时候总出问题,现在找到一个能测试的代码,自己先看看和原来的那个代码有啥不同,后面会继续更新,说下 ...
- Strtus配置Tomcat出现问题
在使用 eclipse 过程中,如果你加入了某些自定义的框架(比如 struts)后,在启动 services 后, 控制台出现一片红色的字样,表明有问题.这时仔细查看 eclipse 控制台信息, ...