javascript快速入门15--节点
节点类型
DOM定义了Node的接口以及许多种节点类型来表示节点的多个方面!
- Document——最顶层的节点,所有的其他节点都是附属于它的。
- DocumentType——DTD引用(使用<!DOCTYPE >语法)的对象表现形式,例如<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" >。它不能包含子节点。
- DocumentFragment——可以像Document一样来保存其他节点。
- Element——表示起始标签和结束标签之间的内容,例如<tag ></tag >或者<tag / >。这是唯一可以同时包含特性和子节点的节点类型。
- Attr——代表一对特性名和特性值。这个节点类型不能包含子节点。
- Text——代表XML文档中的在起始标签和结束标签之间,或者CData Section内包含的普通文本。这个节点类型不能包含子节点。
- CDataSection——<![CDATA[ ]]>的对象表现形式。这个节点类型仅能包含文本节点Text作为子节点。
- Entity——表示在DTD中的一个实体定义,例如<!ENTITY foo "foo">。这个节点类型不能包含子节点。
- EntityReference——代表一个实体引用,例如"。这个节点类型不能包含子节点。
- ProcessingInstruction——代表一个PI(处理指令)。这个节点类型不能包含子节点。
- Comment——代表注释。这个节点类型不能包含子节点。
- Notation——代表在DTD中定义的记号。这个很少用到,所以我们不会讨论。
还定义了对应不同节点类型的12个常量.
- Node.ELEMENT_NODE (1)
- Node.ATTRIBUTE_NODE (2)
- Node.TEXT_NODE (3)
- Node.CDATA_SECTION_NODE (4)
- Node.ENTITY_REFERENCE_NODE (5)
- Node.ENTITY_NODE (6)
- Node.PROCESSING_INSTRUCTION_NODE (7)
- Node.COMMENT_NODE (8)
- Node.DOCUMENT_NODE (9)
- Node.DOCUMENT_TYPE_NODE (10)
- Node.DOCUMENT_FRAGMENT_NODE (11)
- Node.NOTATION_NODE (12)
节点类型常量都是Node对象的属性,但是IE不支持Node对象,但是仍可以使用数值
Node接口也定义了一些所有节点类型都包含的特性和方法。我们在下面的表格中列出了这些特性和方法:
特性/方法 | 类型/返回类型 | 说 明 |
nodeName | String | 节点的名字;根据节点的类型而定义,元素节点返回tagName,文本节点返回#text,属性节点返回属性名 |
nodeValue | String | 节点的值;根据节点的类型而定义.元素节点此属性为空,文本节点些属性即为节点中的字符串,属性节点返回属性值 |
nodeType | Number | 节点的类型常量值之一 |
ownerDocument | Document | 指向这个节点所属的文档 |
firstChild | Node | 指向在childNodes列表中的第一个节点 |
lastChild | Node | 指向在childNodes列表中的最后一个节点 |
childNodes | NodeList | 所有子节点的列表 |
previousSibling | Node | 指向前一个兄弟节点;如果这个节点就是第一个兄弟节点,那么该值为null |
nextSibling | Node | 指向后一个兄弟节点;如果这个节点就是最后一个兄弟节点,那么该值为null |
hasChildNodes() | Boolean | 当childNodes包含一个或多个节点时,返回真 |
attributes | NamedNodeMap | 包含了代表一个元素的特性的Attr对象;仅用于Element节点 |
appendChild(node) | Node | 将node添加到childNodes的末尾 |
removeChild(node) | Node | 从childNodes中删除node |
replaceChild (newnode,oldnode) | Node | 将childNodes中的oldnode替换成newnode |
insertBefore (newnode,refnode) | Node | 在childNodes中的refnode之前插入newnode |
除节点外,DOM还定义了一些助手对象,它们可以和节点一起使用,但不是DOM文档必有的部分。
- NodeList——节点数组,按照数值进行索引;用来表示一个元素的子节点。比如childNodes。NodeList有个length属性表示节点数量
- NamedNodeMap——同时用数值和名字进行索引的节点表;用于表示元素特性。比如元素的attributes。NamedNodeMap对象也有一个length属性来指示它所包含的节点的数量。
这些助手对象为处理DOM文档提供附加的访问和遍历方法。
属性节点
正如前面提到的,即便Node接口已具有attributes方法,且已被所有类型的节点继承,然而,只有Element节点才能有特性。Element节点的attributes属性其实是NamedNodeMap,它提供一些用于访问和处理其内容的方法:
- getNamedItem(name)——返回nodeName属性值等于name的节点;
- removeNamedItem(name)——删除nodeName属性值等于name的节点;
- setNamedItem(node)——将node添加到列表中,按其nodeName属性进行索引;
- item(pos)——像NodeList一样,返回在位置pos的节点;
请记住这些方法都是返回一个Attr节点,而非特性值。
当NamedNodeMap用于表示特性时,其中每个节点都是Attr节点,它的nodeName属性被设置为特性名称,而nodeValue属性被设置为特性的值。示例:
<p id="p1" style="background-color:red;" title="P!!!">Some Text!</p>
var p1 = document.getElementById("p1");
//访问ID属性
alert(p1.attributes.getNamedItem("id")).nodeValue;
//也可以用数值来访问ID属性
alert(p1.attributes.item(0)).nodeValue;
//也可以改变它的值
p1.attributes.getNamedItem("id").nodeValue = "newP1";
Attr节点也有一个完全等同于(同时也完全同步于)nodeValue属性的value属性,并且有name属性和nodeName属性保持同步。我们可以随意使用这些属性来修改或变更特性。但这些方法都比较复杂,所以DOM又定义了三个元素方法来帮助访问特性:
- getAttribute(name)——等于attributes.getNamedItem(name).value
- setAttribute(name, newValue)——等于attribute.getNamedItem(name).value = newValue
- removeAttribute(name)——等于attributes.removeNamedItem(name)
NodeList
事实上我们早接触过NodeList了
var allTags = document.getElementsByTagName("*");
alert(allTags.item(1).tagName);//访问了第二个元素
alert(allTags[0]);//在JavaScript可以这样访问第一个元素,但这只能是JavaScript里正常运行
getElementsByTagName与getElementsByName都返回NodeList,可以使用item(index)方法访问其中的内容,在JavaScript中还可使用数组形式的下标访问!
创建和操纵节点
迄今为止,已经学过了如何访问文档中的不同节点,不过这仅仅是使用DOM所能实现的功能中的很小一部分。还能添加、删除、替换(或者其他操作)DOM文档中的节点。正是这些功能使得DOM具有真正意义上的动态性。
创建新节点
DOM Document(文档)中有一些方法用于创建不同类型的节点,即便在所有的浏览器中的浏览器document对象并不需要全部支持所有的方法。下面的表格列出了包含在DOM Level 1中的方法,并列出不同的浏览器是否支持项。
方 法 | 描 述 | IE | MOZ | OP | SAF |
createAttribute (name) | 用给定名称name创建特性节点 | × | × | × | - |
createCDATASection (text) | 用包含文本text的文本子节点创建一个CDATA Section | - | × | - | - |
createComment(text) | 创建包含文本text的注释节点 | × | × | × | × |
createDocumentFragment() | 创建文档碎片节点 | × | × | × | × |
createElement (tagname) | 创建标签名为tagname的元素 | × | × | × | × |
createEntity Reference(name) | 创建给定名称的实体引用节点 | - | × | - | - |
createProcessing Instruction(target, data) | 创建包含给定target和data的PI节点 | - | × | - | - |
createTextNode(text) | 创建包含文本text的文本节点 | × | × | × | × |
注:IE = Windows的IE 6;MOZ = 任意平台的Mozilla 1.5;OP=任意平台的Opera 7.5;SAF=MacOS的Safari 1.2
最常用到的几个方法是:createDocumentFragment()、createElement()和createText- Node();其他的一些方法要么就是没什么用(createComment()),要么就是浏览器的支持不够,目前还不太能用。
动态创建一个段落示例
var p = document.createElement("p");//创建一个元素节点,传入标签名
var txt = document.createTextNode("创建文本节点,传参数即是文本内容");
p.appendChild(txt);//将txt所引用的文本节点插入p到p的最后面(在这里p是空的)
//直到现在,页面不会出现任何内容,必须将创建的节点插入到文档中
document.body.appendChild(p);//p将出现在最后
移动,删除节点方法及注意事项——appendChild,removeChild,replaceChild,insertBefore
var p1 = document.getElementById("p1");
document.body.appendChild(p1);//p1将会被作为body的最后一个子节点,然而页面上仍只有一个p
p1.parentNode.removeChild(p1);//removeChild必须是要删除的节点的父节点调用
//p1将会从页面上消失,然而它并没有完全消失,我们还可以再将其插入文档
document.body.appendChild(p1);//因为变量p1包含了节点的引用
var p2 = document.getElementById("p2");
p2.parentNode.replaceChild(p1,p2);//p2将会被替换成p1,p2将消失
//而p1将从原来的位置移到p2的位置
克隆节点——cloneNode
基于上面的原因,DOM为我们提供了一个克隆节点的方法用于生成一个节点的副本
var p1 = document.getElementById("p1");
var p2 = p1.cloneNode();
document.body.appendChild(p2);//页面上将会多出一个段落,不过段落中什么都没有
p2 = p1.cloneNode(true);//使用参数true表示克隆节点时包含子节点
document.body.appendChild(p2);
javascript快速入门15--节点的更多相关文章
- JavaScript快速入门(四)——JavaScript函数
函数声明 之前说的三种函数声明中(参见JavaScript快速入门(二)——JavaScript变量),使用Function构造函数的声明方法比较少见,我们暂时不提.function func() { ...
- Javascript快速入门(上篇)
Javascript的熟练之路,小弟来了. JavaScript简介:JavaScript一种直译式脚本语言,是一种动态类型.弱类型.基于原型的语言,内置支持类型.它的解释器被称为JavaScript ...
- Javascript快速入门(下篇)
Javascript, cheer up. Ajax:其通过在Web页面与服务器之间建立一个额外的处理层,这个处理层就被称为Ajax引擎,它解释来自用户的请求,在后台以异步的方式处理服务器通信,其结构 ...
- Web开发初探之JavaScript 快速入门
本文改编和学习自 A JavaScript Primer For Meteor 和 MDN Web教程 前文 Web开发初探 概述 本文以介绍 JavaScript 为主,初学者掌握本文的内容后,将能 ...
- javascript快速入门
这个在w3school在线文档讲解的很详细,还能在线练习. 所以我只写一些入门的东西和最常用的总结以及注意事项: JavaScript 是脚本语言 一般被人们称为JS,Jquery就是对js语言的封装 ...
- JavaScript快速入门(六)——DOM
概念扫盲 DOM DOM是 Document Object Model(文档对象模型)的缩写,是W3C(万维网联盟)的标准.DOM 定义了访问 HTML 和 XML 文档的标准:“W3C 文档对象模型 ...
- JavaScript快速入门(三)——JavaScript语句
JavaScript基本语句 基本概述 JavaScript是脚本语言,从上到下解释执行,最小单位为语句或语句块,每个语句以分号结尾,每个语句块以右大括号结尾. JavaScript可以将多条语句或语 ...
- JavaScript快速入门-简介
一.JavaScript历史(摘自w3school) JavaScript 是因特网上最流行的脚本语言,它存在于全世界所有 Web 浏览器中,能够增强用户与 Web 站点和 Web 应用程序之间的交互 ...
- JavaScript快速入门-ECMAScript本地对象(String)
一.String对象 String对象和python中的字符串一样,也有很多方法,这些方法大概分为以下种类: 1.索引和查找 1.charAt() 返回指定位置的字符. 2.charCodeAt( ...
- JavaScript快速入门-DOM对象
一.概述 1.什么是 DOM? DOM 是 W3C(万维网联盟)的标准.DOM 定义了访问 HTML 和 XML 文档的标准: "W3C 文档对象模型(DOM)是中立于平台和语言的接口,它允 ...
随机推荐
- [FZU2261]浪里个浪
TonyY是一个喜欢到处浪的男人,他的梦想是带着兰兰姐姐浪遍天朝的各个角落,不过在此之前,他需要做好规划. 现在他的手上有一份天朝地图,上面有n个城市,m条交通路径,每条交通路径都是单行道.他已经预先 ...
- Java内存区域与内存异常
参考:深入理解Java虚拟机 周志明 方法区 虚拟机战 本地方法栈 堆 程序计数器 其他 设置 方法区 线程共享,加载类信息.常量.静态变量.JIT后的代码,别名Non-Heap 对于HotSpot, ...
- ios 里如何处理四舍五入的问题
http://blog.sina.com.cn/s/blog_a2774bb10101293j.html 今天朋友问我一个问题,就是如何只舍不入.比如 float price = 0.126,怎么样才 ...
- tmux下vim颜色不正常问题
在解决了tmux下,make menuconfig颜色不正常问题https://www.cnblogs.com/zqb-all/p/9702582.html后,引入了新的问题,vim颜色错乱. 尝试了 ...
- VS mfc MessageBox() 使用英文显示
转载:http://blog.csdn.net/guoyk1990/article/details/44337249 由于特殊原因我们需要将 MessageBox 或 Dialog 的按钮“确定”.“ ...
- Windows下卸载Oracle
先在软件运行界面卸载 Oracle 一.删掉主目录 二.删除注册表内容. 运行regedit命令,删除下面内容: --1.HKEY_CLASSES_ROOT,删除此键下所有以Ora,Oracl ...
- servlet(5) - Cookie和session - 小易Java笔记
1.会话概述 (1)会话可简单理解为:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话. (2)会话过程中的数据不宜保存在request和servle ...
- mvvm command的使用案例
主界面如下: 前台代码: <Window x:Class="WpfApp1.MainWindow" xmlns="http://schemas.mic ...
- 使用python获取整月每一天的系统监控数据生成报表
1.安装阿里开源监控工具tsar tsar官方网站 wget -O tsar.zip https://github.com/alibaba/tsar/archive/master.zip --no-c ...
- MySQL存储IP地址
mysql没有提供IP类型,常见的存储多为使用varchar类型.其实使用int型更好,主要原因是便于计算IP段. 具体应用时应设置字段类型为unsigned int.否则无法存储128.x.x.x及 ...