- 浏览: 41538 次
- 性别:
- 来自: 北京
最近访客 更多访客>>
最新评论
-
zhoudaifei:
感觉不错的
Struts中配置文件的详细讲解 -
fan-R:
看的我好辛苦啊,呵呵不错,但是很多关键的地方都没详细讲,只是粗 ...
全面接触Java集合框架 -
jeans:
謝謝分享~
HttpClient 学习整理
DOM的核心: Node
由于DOM是树形结构,所以一个节点被抽象为对象Node,这是DOM的核心对象:
Node的种类一共有12种,通过Node.nodeType的取值来确定(为1-12),分为:
- Node.ELEMENT_NODE (1)
- Node.ATTRIBUTE_NODE (2)
- Node.TEXT_NODE (3) //<![CDATA[ ]]>中括着的纯文本,它没有子节点
- Node.CDATA_SECTION_NODE (4) //子节点一定为TextNode
- Node.ENTITY_REFERENCE_NODE (5)
- Node.ENTITY_NODE (6) //DTD中的实体定义<!ENTITY foo “foo”>,无子节点
- Node.PROCESSING_INSTRUCTION_NODE (7) //PI,无子节点
- Node.COMMENT_NODE (8)
- Node.DOCUMENT_NODE (9) //最外层的Root element,包括所有其它节点
- Node.DOCUMENT_TYPE_NODE (10) //DTD,<!DOCTYPE………..>
- Node.DOCUMENT_FRAGMENT_NODE (11)
- Node.NOTATION_NODE (12) //DTD中的Nation定义
Node.ELEMENT_NODE (1) Node.ATTRIBUTE_NODE (2) Node.TEXT_NODE (3) //<![CDATA[ ]]>中括着的纯文本,它没有子节点 Node.CDATA_SECTION_NODE (4) //子节点一定为TextNode Node.ENTITY_REFERENCE_NODE (5) Node.ENTITY_NODE (6) //DTD中的实体定义<!ENTITY foo “foo”>,无子节点 Node.PROCESSING_INSTRUCTION_NODE (7) //PI,无子节点 Node.COMMENT_NODE (8) Node.DOCUMENT_NODE (9) //最外层的Root element,包括所有其它节点 Node.DOCUMENT_TYPE_NODE (10) //DTD,<!DOCTYPE………..> Node.DOCUMENT_FRAGMENT_NODE (11) Node.NOTATION_NODE (12) //DTD中的Nation定义
❑ Node接口包含的特性/方法
节点的属性
nodeName 属性将返回一个字符串,其内容是给定节点的名字。如果节点是元素节点,返回这个元素的名称;如果是属性节点,返回这个属性的名称;如果是文本节点,返回一个内容为#text 的字符串;
nodeType 属性将返回一个整数,这个数值代表给定节点的类型
nodeValue 属性将返回给定节点的当前值.如果节点是元素节点,返回null;如果是属性节点,返回这个属性的名称;如果是文本节点,返回文本节点的内容;
ownerDocument 指向这个节点所属的文档
attributes 包哈勒代表一个元素的特性的Attr对象;仅用于Element节点
childNodes 所有子节点的列表
firstChild 指向在childNodes列表中的第一个节点
lastChild 指向在childNodes列表中的最后一个节点
nextSibling 指向后一个兄弟节点;如果这个节点就是最后一个兄弟节点,那么该值为null
previousSibling 指向前一个兄弟节点;如果这个节点就是第一个兄弟节点,那么该值为null
parentNode 返回一个给定节点的父节点
❑ hasChildNodes() 当childNodes包含一个或多个节点时,返回真
❑ appendChild(node) 将node添加到childNodes的末尾
❑ removeChild(node) 将node从childNodes中删除
❑ insertBefore(newnode refnode) 在childNodes中的refnode之前插入newnode
- var container = document.getElementById("content");
- var message = document.getElementById("fineprint");
- var para = document.createElement("p");
- container.insertBefore(para,message);
var container = document.getElementById("content"); var message = document.getElementById("fineprint"); var para = document.createElement("p"); container.insertBefore(para,message);
❑ replaceChild(newnode,oldnode)将childNodes中的oldnode替换成newnode
- var container = document.getElementById("content");
- var message = document.getElementById("fineprint");
- var para = document.createElement("p");
- container.replaceChild(para,message);
var container = document.getElementById("content"); var message = document.getElementById("fineprint"); var para = document.createElement("p"); container.replaceChild(para,message);
❑ 获得Node:
- /* 通过document对象 */
- var oHtml = document.documentElement;
- /* 得到<head />和<body /> */
- var oHead = oHtml.firstChild;
- var oBody = oHtml.lastChild;
- /* 可以用这种方式 */
- var oHead = oHtml.childNodes[0];
- var oBody = oHtml.childNodes[1];
- /* 也可以使用方法获取数组的索引值 */
- var oHead = oHtml.childNodes.item(0);
- var oBody = oHtml.childNodes.item(1);
- /* 使用document.body来得到<body /> */
- var oBody = document.body;
/* 通过document对象 */ var oHtml = document.documentElement; /* 得到<head />和<body /> */ var oHead = oHtml.firstChild; var oBody = oHtml.lastChild; /* 可以用这种方式 */ var oHead = oHtml.childNodes[0]; var oBody = oHtml.childNodes[1]; /* 也可以使用方法获取数组的索引值 */ var oHead = oHtml.childNodes.item(0); var oBody = oHtml.childNodes.item(1); /* 使用document.body来得到<body /> */ var oBody = document.body;
❑ createElement(element)
创建一个指定标签名创建一个新的元素节点,返回值为指向新建元素节点的引用指针。
eg) var para = document.createElement("p");
document.body.appendChild(para);
❑ createTextNode()
创建一个包含着给定文本的新文本节点,返回一个指向新建文本节点的引用指针:
reference = document.createTextNode()
参数为新建文本节点所包含的文本字符串
- var message = document.createTextNode("hello world");
- var container = document.createElement("p");
- container.appendChild(message);
- document.body.appendChild(container);
var message = document.createTextNode("hello world"); var container = document.createElement("p"); container.appendChild(message); document.body.appendChild(container);
❑ cloneNode()
reference = node.cloneNode(deep)
为给定节点创建一个副本,参数为 true 或者 false,true 表示同时复制该节点的子节点,false 则不复制任何子节点。
- var para = document.createElement("p");
- var message = document.createTextNode("hello world");
- para.appendChild(message);
- document.body.appendChild(para);
- var newpara = para.cloneNode(true);
- document.body.appendChild(newpara);
var para = document.createElement("p"); var message = document.createTextNode("hello world"); para.appendChild(message); document.body.appendChild(para); var newpara = para.cloneNode(true); document.body.appendChild(newpara);
❑ 检测节点类型
通过使用nodeType特性检验节点类型:
alert(document.nodeType); //outputs "9"
alert(document.documentElement.nodeType); //outputs "1"
这个例子中,document.nodeType返回9,等于Node.DOCUMENT_NODE;同时document. documentElement.nodeType返回1,等于Node.ELEMENT_NODE。
也可以用Node常量来匹配这些值:
alert(document.nodeType == Node.DOCUMENT_NODE); //true
alert(document.documentElement.nodeType == Node.ELEMENT_NODE); //true
这段代码可以在Mozilla 1.0+、Opera 7.0+和Safari 1.0+上正常运行。但是IE不支持这些常量,所以这些代码在IE上会产生错误。
❑ 处理特性
即便Node接口已具有attributes方法,且已被所有类型的节点继承,然而,只有Element节点才能有特性。
Element节点的attributes属性其实是NamedNodeMap,它提供一些用于访问和处理其内容的方法:
getNamedItem(name) 返回nodeName属性值等于name的节点;
removeNamedItem(name) 删除nodeName属性值等于name的节点;
setNamedItem(node) 将node添加到列表中,按其nodeName属性进行索引;
item(pos) 像NodeList一样,返回在位置pos的节点;
请记住这些方法都是返回一个Attr节点,而非特性值。
NamedNodeMap对象也有一个length属性来指示它所包含的节点的数量。
当NamedNodeMap用于表示特性时,其中每个节点都是Attr节点,它的nodeName属性被设置为特性名称,而nodeValue属性被设置为特性的值。
例如,假设有这样一个元素:
<p id="p1" style="color:red">hello world!</p>
假设变量oP包含指向这个元素的一个引用。于是可以这样访问id特性的值:
var sId = oP.attributes.getNamedItem("id").nodeValue; //p1
或者
var sId = oP.attributes.item(0).nodeValue;
还可以通过给nodeValue属性赋新值来改变id特性:
oP.attributes.getNamedItem("id").nodeValue = "newId";
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)
要获取前面用的<p/>的id特性,只需这样做:
var sId = oP.getAttribute("id");
更改ID:
oP.setAttribute("id", "newId");
❑ setAttribute()
element.setAttribute(attributeName,attributeValue);
为给定元素节点添加一个新的属性值或是改变它的现有属性
❑ getAttribute
attributeValue = element.getAttribute(attributeName)
返回一个给定元素的一个给定属性节点的值。
❑ getElementById()
element = document.getElementById(ID)
寻找一个有着给定 id 属性值的元素,返回一个元素节点
❑ getElementsByName()
用来获取所有name特性等于指定值的元素:
elements = document.getElementsByName(tagName)
返回一个节点集合。
❑ getElementsByTagName()
用于寻找有着给定标签名的所有元素:
elements = document.getElementsByTagName(tagName)
返回一个节点集合。
❑ 生成与操作Node
createAttribute(name) :创建一个名为name的属性节点。
createCDATASection(text) :创建一个子节点为text的CDATA区。
createComment(text) :创建一个注释内容为text的注释节点。
createDocumentFragment() :创建一个文档片断(fragment)节点。
createElement(tagName) :创建一个名为tagName的元素节点。
createEntityReference(name) :Creates an entity reference node with the given name。
createProcessingInstruction(target, data) :Creates a PI node with the given target and data。
createTextNode(text) :创建一个包含text的文本节点。
其中最重要的方法是createElement(),createDocumentFragment(), create TextNode()。
- /*使用createElement(),createTextNode(),appendChild()动态添加节点*/
- function createMessage(){
- var op = document.createElement("p");
- var oText = document.createTextNode("hello world!");
- op.appendChild(oText);
- document.body.appendChild(op);
- }
/*使用createElement(),createTextNode(),appendChild()动态添加节点*/ function createMessage(){ var op = document.createElement("p"); var oText = document.createTextNode("hello world!"); op.appendChild(oText); document.body.appendChild(op); }
❑ 使用createDocumentFragment()
- //通常做法
- var arrText = ['first', 'second', 'third'];
- for(var i=0; i<arrText.length; i++){
- var op = document.createElement('p');
- var oText = document.createTextNode(arrText[i]);
- op.appendChild(oText);
- document.body.appendChild(op);
- }
- //使用documentFragment
- var arrText = ['first', 'second', 'third'];
- var oFragment = document.createDocumentFragment();
- for(var i=0; i<arrText.length; i++){
- var op = document.createElement('p');
- var oText = document.createTextNode(arrText[i]);
- op.appendChild(oText);
- oFragment.appendChild(op);
- }
- document.body.appendChild(oFragment);
//通常做法 var arrText = ['first', 'second', 'third']; for(var i=0; i<arrText.length; i++){ var op = document.createElement('p'); var oText = document.createTextNode(arrText[i]); op.appendChild(oText); document.body.appendChild(op); } //使用documentFragment var arrText = ['first', 'second', 'third']; var oFragment = document.createDocumentFragment(); for(var i=0; i<arrText.length; i++){ var op = document.createElement('p'); var oText = document.createTextNode(arrText[i]); op.appendChild(oText); oFragment.appendChild(op); } document.body.appendChild(oFragment);
通过DocumentFragment的方式效率更高。
❑ HTML DOM:
使用DOM的核心方法是针对所有XML的,针对HTML DOM有特殊的方法,如
使用DOM core:oImg.setAttribute("src", "picture.gif");
使用HTML DOM:oImg.src = "picture.jpg";
发表评论
-
js日期时间函数(经典+完善+实用)
2008-09-11 17:19 1088来自http://new.dlgzy.com/bbs/show ... -
js如何判断输入是否为正整数、浮点数等数字的函数
2008-09-04 10:57 64911.下面列出了一些判读数值类型的正则表达式 " ... -
Jakarta-Common-BeanUtils使用笔记
2008-08-15 11:50 10921. 概述 第一次接触BeanUtils是在学 ... -
DWR小结DWRUtil篇
2008-07-18 17:26 4138$(); 功能:相当于document.g ... -
JSTL语法及参数详解
2008-06-18 14:48 1002JSTL语法及参数 JSTL包含以下的标签: 常用的标 ... -
Java.lang.reflect包介绍
2008-05-30 16:55 1638特此声明这些资料的原始内容来自www.java.sun.com ... -
STRUTS的struts--config.xml详解
2008-02-29 16:04 1472<?xml version="1.0" ... -
Struts中配置文件的详细讲解
2008-02-28 10:05 1945Struts应用采用两个基 ... -
Struts异常处理(转)
2008-02-28 09:57 1330Struts异常处理(转自http://www.blogjav ... -
全面接触Java集合框架
2008-02-25 15:32 3514Java平台提供了一个全新的集合框架。“集合框架”主要由一组用 ... -
java.util.concurrent 多线程框架
2008-01-07 09:58 3149(来源于http://www.zhuaxia.com/item ... -
字符,字节和编码
2008-01-07 09:50 876摘要:本文介绍了字符与编码的发展过程,相关概念的正确理解。举例 ... -
使用JDBC和Hibernate来写入Blob型数据到Oracle中
2008-01-07 09:49 763Oracle的Blob字段比较特殊,他比long字段的性能要好 ... -
HttpClient 学习整理
2008-01-07 09:47 1523HttpClient 是我最近想研 ...
相关推荐
根据提供的文件信息,我们可以推断出这是一本关于JavaScript DOM编程技术的书籍——《JavaScript DOM编程艺术(第2版)》。尽管实际书籍内容并未给出,但从标题、描述及部分链接信息来看,这本书主要涉及JavaScript...
3. **JavaScript-DOM-Cheatsheet.pdf**:这份资料可能提供了JavaScript操作DOM的快捷方法和常见任务示例,如添加、删除和修改DOM元素。 4. **csscheatsheet.pdf**:这可能是一个通用的CSS速查表,涵盖了更广泛的CSS...
总的来说,JavaScript DOM2是Web开发中的关键工具,它让JavaScript成为了一种强大的客户端脚本语言,为网页带来了丰富的动态性和交互性。通过学习和实践,开发者可以提高网页的用户体验,创建出更加智能和灵活的Web...
JavaScript API是JavaScript语言在浏览器环境下的扩展,提供了访问和操作DOM、处理用户交互、进行Ajax通信等功能。例如,Document对象的getElementById()用于获取ID为特定值的元素,Event对象提供了事件处理相关的...
《JavaScript DOM高级程序设计》是一本深入探讨JavaScript与DOM(Document Object Model)交互的权威书籍。这本书的源码提供了一种实践的方式,帮助读者更好地理解书中的理论知识,并且能够亲手实现书中提到的各种...
DOM提供了添加、删除、修改文档元素的方法,使得JavaScript能够动态改变网页内容。书中会详细讲解如何通过JavaScript访问DOM元素,如通过ID、类名、标签名等选择器选取元素,以及遍历DOM树的各种技巧。 在实际开发...
下面将详细探讨DOM的基础概念、核心特性以及在JavaScript中的应用。 ### 一、DOM基础概念 #### 1.1 定义 文档对象模型(DOM)是一种用于HTML和XML文档的标准平台和语言中立接口。它定义了标记语言文档的标准模型,...
这本书可能会从这些基础概念讲起,逐步引导读者了解JavaScript的高级特性。 2. HTML和CSS知识:虽然这些不是JavaScript的一部分,但它们是构建Web页面的标准技术,JavaScript经常与它们一起使用来控制网页的表现...
《JavaScript DOM 高级程序设计》是一本深入探讨JavaScript与DOM(Document Object Model)交互的专著,旨在帮助读者掌握高级的DOM操作技巧,提升Web前端开发能力。这本书的配套源代码提供了书中所有示例的实际实现...
书中还强调了JavaScript的面向对象编程特性,并展示了如何利用这些特性来组织DOM相关的代码,提高代码的可读性和可维护性。面向对象编程在DOM编程中尤为重要,因为它可以帮助我们封装复杂的功能,创建可复用的对象和...
JavaScript+DOM编程艺术是前端开发领域的一本经典著作,它深入浅出地讲解了JavaScript语言与DOM(Document Object Model)的交互技术。DOM是Web页面的结构化表示,JavaScript则是与DOM进行互动的主要脚本语言,这...
9. **现代JavaScript与DOM**:可能涉及ES6及更高版本的新特性,如箭头函数、模板字符串、Promise等,以及它们在DOM编程中的应用。 10. **DOM库和框架**:介绍jQuery和其他流行的DOM库,如React、Vue等,它们如何...
总之,《JavaScript DOM编程艺术第二版高清(中文)》是一本全面且深入的教程,它不仅涵盖了JavaScript的基本语法和DOM操作,还关注了HTML5的新特性,是Web前端开发者的必备读物。通过阅读此书,读者将能够熟练掌握...
《JavaScript+DOM编程艺术》是一本深受欢迎的IT图书,主要针对JavaScript和DOM(文档对象模型)的编程技术进行深入浅出的讲解。作者通过简洁明快的写作风格,使得复杂的Web前端开发概念变得通俗易懂,适合初学者及有...
- **JavaScript语法特性**: - **变量命名规则**:JavaScript变量名是大小写敏感的,变量名中不允许包含空格或大部分标点符号(美元符号"$"除外)。变量名可以包含字母、数字、美元符号和下划线。 - **数据类型**...
JavaScript Enlightenment可能详细讲解了这些基础知识,包括变量、数据类型、控制结构、函数、对象、数组、正则表达式等,并深入到ES6及后续版本的新特性,如箭头函数、Promise、async/await等。 DOM是HTML和XML...
书中的第二版更新了现代JavaScript语法和API的使用,如ES6的新特性,以及现代浏览器提供的DOM接口,如MutationObserver用于监听DOM变化。 本书内容可能包括以下几个方面: 1. JavaScript基础:介绍变量、数据类型...
通过学习《JavaScript DOM编程艺术》的源代码,读者不仅可以掌握基本的DOM操作,还能深入了解如何结合JavaScript的最新特性来构建现代、动态的Web应用程序。实践中遇到的问题和解决方案都可能成为提升技能的关键点。