5、Node对象

u  遍历节点

u 父节点

.parentNode - 获取父节点—> 元素节点或文档节点

.parentElement - 获取父元素节点—> 元素节点

u    子节点

.childNodes – 获取所有子节点;

.firstChild – 获取第一个子节点;     .lastChild – 获取最后一个子节点

u    兄弟节点

.previousSibling - 上一个兄弟节点;    .nextSibling - 下一个兄弟节点

L 空白节点问题:

概念:空白节点,实际上就是一个空的文本节点

原因: 编写HTML代码时,输入换行符,浏览器解析HTML页面为DOM结构时,自动添加空白节点    ---获取子节点及兄弟节点的属性不能正常使用

注:IE8及以下版本的浏览器不存在空白节点问题

  • 解决方案

1. 弃用获取子节点和兄弟节点的属性;改用getElementsByTagName( ) 方法

从父级根据标签名得到所有子级,选[0];   自动把空白节点去掉

  1. 使用原本的子节点属性,人为进行判断,进行重构
  • 封装方法:

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对象)的更多相关文章

  1. HTML DOM基础知识

    HTML DOM基础知识 一.什么是DOM? 1.HTML DOM 定义了访问和操作HTML文档的标准方法. 2.HTML DOM 把 HTML 文档呈现为带有元素.属性和文本的树结构(节点树). 3 ...

  2. C/C++基础知识总结——类与对象

    1. 面向对象程序设计的特点 1.1 抽象 1.2 封装 1.3 继承 1.4 多态 (1) 分为:强制多态.重载多态.类型参数化多态.包含多态 (2) 强制多态:类型转换 重载多态: 类型参数化多态 ...

  3. JAVA核心技术I---JAVA基础知识(不可变对象和字符串)

    一:不可变对象 不可变对象(Immutable Object) –一旦创建,这个对象(状态/值)不能被更改了–其内在的成员变量的值就不能修改了. –典型的不可变对象 • 八个基本型别的包装类的对象 • ...

  4. Js基础知识2-对象、对象属性全解

    Object对象 Object对象包含如下属性和方法,也就意味着一切对象(函数也是对象)都包含如下方法. 每种方法和属性在不同的对象中有不同的作用,并不是每种对象都有使用每个方法的必要. 下面是Obj ...

  5. DOM基础知识(概念、节点树、事件、Document)

    1.   DOM概念 全称为 Document Object Model,译为文档对象模型 D:文档 - DOM将HTML页面解析为一个文档 —> document对象 O:对象 - DOM将H ...

  6. DOM中的node与element的区别

    先看document的两个常见method. document.createTextNode Constructor: Text document.createElement Constructor: ...

  7. 工作随笔—Java容器基础知识分享(持有对象)

    1. 概述 通常,程序总是运行时才知道的根据某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型,为解决这个普遍的编程问题:需要在任意时刻和任意位置创建任意数量的对象,所以,就 ...

  8. java 基础知识九 类与对象

    java  基础知识九  类与对象 1.OO(Object–Oriented )面向对象,OO方法(Object-Oriented Method,面向对象方法,面向对象的方法)是一种把面向对象的思想应 ...

  9. 《Java基础知识》Java多态对象的类型转换

    这里所说的对象类型转换,是指存在继承关系的对象,不是任意类型的对象.当对不存在继承关系的对象进行强制类型转换时,java 运行时将抛出 java.lang.ClassCastException 异常. ...

随机推荐

  1. ReactiveX Operators

    This documentation groups information about the various operators and examples of their usage into t ...

  2. jquery选择器的一些处理

    本文不讨论用jquery选择器具体怎么选择页面元素,而讨论选择元素后后的一些处理 jquery的选择器选择元素的时候,即使没有选择到指定的对象,页面并不会报错,例子: <!doctype htm ...

  3. Bootstrap 有一个 class 属性叫做 well,它的作用是为设定的列创造出一种视觉上的深度感

    Bootstrap 有一个 class 属性叫做 well,它的作用是为设定的列创造出一种视觉上的深度感

  4. jQuery添加新的元素

    append() - 在被选元素的结尾插入内容 prepend() - 在被选元素的开头插入内容 after() - 在被选元素之后插入内容 before() - 在被选元素之前插入内容 $(&quo ...

  5. 克隆CentOS 6.9 配置静态IP,重启网络服务时报错

    克隆的CentOS 6.9 第一次开机时,VMware workstation会为新虚拟机自动生成新mac地址,导致虚拟机配置文件中mac地址与虚拟机新mac地址不一致. 解决方法:1. 修改网卡配置 ...

  6. C++基础 (8) 第八天 数组指针 模板指针 C语言中的多态 模板函数

    1昨日回顾 2 多态的练习-圆的图形 3多态的练习-程序员薪资 4员工管理案例-抽象类和技术员工的实现 employee.h: employee.cpp: technician.h: technici ...

  7. 实验一:JAVA实验环境搭建 ,JDK下载与安装及 Eclipse下载与安装

    一.搭建JAVA实验环境 1.JDK的下载 (1)打开 IE 浏览器,输入网址“http://www.oracle.com/index.html”,浏览 Oracle 官方主页.鼠标双击Downloa ...

  8. JavaScript 数字字符串比较大小

    JavaScript中常用数字字符串比较 1.数字与数字之间直接比较 比较方式依据数学运算,没什么好说的. 2.数字与字符串数字之间直接比较 例如 数字5 与字符串数字'123',这种比较先将数字字符 ...

  9. 【ACM-ICPC 2018 南京赛区网络预赛 L】Magical Girl Haze

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 定义dis[i][j]表示到达i这个点. 用掉了j次去除边的机会的最短路. dis[1][0]= 0; 在写松弛条件的时候. 如果用 ...

  10. POJ 3228 Gold Transportation

    Gold Transportation Time Limit: 2000ms Memory Limit: 65536KB This problem will be judged on PKU. Ori ...