`
wangyong
  • 浏览: 41654 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

javaScript DOM特性/方法

    博客分类:
  • JAVA
阅读更多

DOM的核心: Node
由于DOM是树形结构,所以一个节点被抽象为对象Node,这是DOM的核心对象:
Node的种类一共有12种,通过Node.nodeType的取值来确定(为1-12),分为:

Js代码 复制代码
  1. Node.ELEMENT_NODE (1)   
  2. Node.ATTRIBUTE_NODE (2)   
  3. Node.TEXT_NODE (3) //<![CDATA[ ]]>中括着的纯文本,它没有子节点   
  4. Node.CDATA_SECTION_NODE (4) //子节点一定为TextNode   
  5. Node.ENTITY_REFERENCE_NODE (5)   
  6. Node.ENTITY_NODE (6) //DTD中的实体定义<!ENTITY foo “foo”>,无子节点   
  7. Node.PROCESSING_INSTRUCTION_NODE (7) //PI,无子节点   
  8. Node.COMMENT_NODE (8)   
  9. Node.DOCUMENT_NODE (9) //最外层的Root element,包括所有其它节点   
  10. Node.DOCUMENT_TYPE_NODE (10) //DTD,<!DOCTYPE………..>   
  11. Node.DOCUMENT_FRAGMENT_NODE (11)   
  12. 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

Js代码 复制代码
  1. var container = document.getElementById("content");   
  2. var message = document.getElementById("fineprint");   
  3. var para = document.createElement("p");   
  4. 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

Js代码 复制代码
  1. var container = document.getElementById("content");   
  2. var message = document.getElementById("fineprint");   
  3. var para = document.createElement("p");   
  4. container.replaceChild(para,message);  
var container = document.getElementById("content");
var message = document.getElementById("fineprint");
var para = document.createElement("p");
container.replaceChild(para,message);

❑ 获得Node:

Js代码 复制代码
  1. /* 通过document对象 */  
  2. var oHtml = document.documentElement;   
  3.   
  4.   
  5. /* 得到<head />和<body /> */  
  6. var oHead = oHtml.firstChild;   
  7. var oBody = oHtml.lastChild;   
  8. /* 可以用这种方式 */  
  9. var oHead = oHtml.childNodes[0];   
  10. var oBody = oHtml.childNodes[1];   
  11. /* 也可以使用方法获取数组的索引值 */  
  12. var oHead = oHtml.childNodes.item(0);   
  13. var oBody = oHtml.childNodes.item(1);   
  14. /* 使用document.body来得到<body /> */  
  15. 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()
参数为新建文本节点所包含的文本字符串

Js代码 复制代码
  1. var message = document.createTextNode("hello world");   
  2. var container = document.createElement("p");   
  3. container.appendChild(message);   
  4. 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 则不复制任何子节点。

Js代码 复制代码
  1. var para = document.createElement("p");   
  2. var message = document.createTextNode("hello world");   
  3. para.appendChild(message);   
  4. document.body.appendChild(para);   
  5. var newpara = para.cloneNode(true);   
  6. 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()。

Js代码 复制代码
  1. /*使用createElement(),createTextNode(),appendChild()动态添加节点*/  
  2. function createMessage(){   
  3. var op = document.createElement("p");   
  4. var oText = document.createTextNode("hello world!");   
  5. op.appendChild(oText);   
  6. document.body.appendChild(op);   
  7. }  
/*使用createElement(),createTextNode(),appendChild()动态添加节点*/
function createMessage(){
 var op = document.createElement("p");
 var oText = document.createTextNode("hello world!");
 op.appendChild(oText);
 document.body.appendChild(op);
}

❑ 使用createDocumentFragment()

Js代码 复制代码
  1. //通常做法   
  2. var arrText = ['first', 'second', 'third'];   
  3. for(var i=0; i<arrText.length; i++){   
  4.     var op = document.createElement('p');   
  5.     var oText = document.createTextNode(arrText[i]);   
  6.      op.appendChild(oText);   
  7.      document.body.appendChild(op);   
  8. }   
  9.   
  10. //使用documentFragment   
  11. var arrText = ['first', 'second', 'third'];   
  12. var oFragment = document.createDocumentFragment();   
  13. for(var i=0; i<arrText.length; i++){   
  14.     var op = document.createElement('p');   
  15.     var oText = document.createTextNode(arrText[i]);   
  16.      op.appendChild(oText);   
  17.      oFragment.appendChild(op);   
  18. }   
  19. 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";

分享到:
评论

相关推荐

    JavaScriptDOM编程艺术(第2版)PDF版本下载.txt

    根据提供的文件信息,我们可以推断出这是一本关于JavaScript DOM编程技术的书籍——《JavaScript DOM编程艺术(第2版)》。尽管实际书籍内容并未给出,但从标题、描述及部分链接信息来看,这本书主要涉及JavaScript...

    Web前端开发手册(Javascript/DOM/CSS)

    3. **JavaScript-DOM-Cheatsheet.pdf**:这份资料可能提供了JavaScript操作DOM的快捷方法和常见任务示例,如添加、删除和修改DOM元素。 4. **csscheatsheet.pdf**:这可能是一个通用的CSS速查表,涵盖了更广泛的CSS...

    javascript dom2 源码及pdf

    总的来说,JavaScript DOM2是Web开发中的关键工具,它让JavaScript成为了一种强大的客户端脚本语言,为网页带来了丰富的动态性和交互性。通过学习和实践,开发者可以提高网页的用户体验,创建出更加智能和灵活的Web...

    常用web开发手册css2/css3/jquery-api/javascript api/dom/html/j2ee-api/dhtml

    JavaScript API是JavaScript语言在浏览器环境下的扩展,提供了访问和操作DOM、处理用户交互、进行Ajax通信等功能。例如,Document对象的getElementById()用于获取ID为特定值的元素,Event对象提供了事件处理相关的...

    javascript DOM高级程序设计源码

    《JavaScript DOM高级程序设计》是一本深入探讨JavaScript与DOM(Document Object Model)交互的权威书籍。这本书的源码提供了一种实践的方式,帮助读者更好地理解书中的理论知识,并且能够亲手实现书中提到的各种...

    JavaScript DOM编程艺术(第2版).pdf

    DOM提供了添加、删除、修改文档元素的方法,使得JavaScript能够动态改变网页内容。书中会详细讲解如何通过JavaScript访问DOM元素,如通过ID、类名、标签名等选择器选取元素,以及遍历DOM树的各种技巧。 在实际开发...

    JavaScriptDOM编程艺术.pdf

    下面将详细探讨DOM的基础概念、核心特性以及在JavaScript中的应用。 ### 一、DOM基础概念 #### 1.1 定义 文档对象模型(DOM)是一种用于HTML和XML文档的标准平台和语言中立接口。它定义了标记语言文档的标准模型,...

    JavaScript DOM编程艺术第二版(英文).pdf

    这本书可能会从这些基础概念讲起,逐步引导读者了解JavaScript的高级特性。 2. HTML和CSS知识:虽然这些不是JavaScript的一部分,但它们是构建Web页面的标准技术,JavaScript经常与它们一起使用来控制网页的表现...

    <<JavaScript DOM 高级程序设计>> 一书的配套源代码

    《JavaScript DOM 高级程序设计》是一本深入探讨JavaScript与DOM(Document Object Model)交互的专著,旨在帮助读者掌握高级的DOM操作技巧,提升Web前端开发能力。这本书的配套源代码提供了书中所有示例的实际实现...

    JavaScript Dom编程艺术

    书中还强调了JavaScript的面向对象编程特性,并展示了如何利用这些特性来组织DOM相关的代码,提高代码的可读性和可维护性。面向对象编程在DOM编程中尤为重要,因为它可以帮助我们封装复杂的功能,创建可复用的对象和...

    JavaScript+DOM编程艺术(最新中文版)

    JavaScript+DOM编程艺术是前端开发领域的一本经典著作,它深入浅出地讲解了JavaScript语言与DOM(Document Object Model)的交互技术。DOM是Web页面的结构化表示,JavaScript则是与DOM进行互动的主要脚本语言,这...

    JavaScript DOM编程艺术

    9. **现代JavaScript与DOM**:可能涉及ES6及更高版本的新特性,如箭头函数、模板字符串、Promise等,以及它们在DOM编程中的应用。 10. **DOM库和框架**:介绍jQuery和其他流行的DOM库,如React、Vue等,它们如何...

    JavaScript_DOM编程艺术第二版高清(中文)

    总之,《JavaScript DOM编程艺术第二版高清(中文)》是一本全面且深入的教程,它不仅涵盖了JavaScript的基本语法和DOM操作,还关注了HTML5的新特性,是Web前端开发者的必备读物。通过阅读此书,读者将能够熟练掌握...

    JavaScript_DOM_编程艺术读书笔记

    - **JavaScript语法特性**: - **变量命名规则**:JavaScript变量名是大小写敏感的,变量名中不允许包含空格或大部分标点符号(美元符号"$"除外)。变量名可以包含字母、数字、美元符号和下划线。 - **数据类型**...

    JavaScript & DOM Enlightenment

    JavaScript Enlightenment可能详细讲解了这些基础知识,包括变量、数据类型、控制结构、函数、对象、数组、正则表达式等,并深入到ES6及后续版本的新特性,如箭头函数、Promise、async/await等。 DOM是HTML和XML...

    JavaScript+DOM编程艺术(PDF格式原版+源代码)

    从JavaScript的基础语法到对象、数组、闭包和原型链等高级特性,再到DOM编程的具体应用,每一步都紧贴实际开发的需求,每一个例子都经过精心设计,确保读者能够通过实际操作来加深理解。 JavaScript作为一种在...

    [JavaScript.DOM编程艺术(第2版)-高清扫描

    书中的第二版更新了现代JavaScript语法和API的使用,如ES6的新特性,以及现代浏览器提供的DOM接口,如MutationObserver用于监听DOM变化。 本书内容可能包括以下几个方面: 1. JavaScript基础:介绍变量、数据类型...

    JavaScript DOM编程艺术 源代码

    通过学习《JavaScript DOM编程艺术》的源代码,读者不仅可以掌握基本的DOM操作,还能深入了解如何结合JavaScript的最新特性来构建现代、动态的Web应用程序。实践中遇到的问题和解决方案都可能成为提升技能的关键点。

Global site tag (gtag.js) - Google Analytics