- 浏览: 329293 次
- 性别:
- 来自: 上海
文章分类
最新评论
❑ 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接口包含的特性/方法
节点的属性
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);
❑ 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);
❑ 获得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;
❑ 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);
❑ 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);
❑ 检测节点类型
通过使用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); }
❑ 使用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);
通过DocumentFragment的方式效率更高。
❑ HTML DOM:
使用DOM的核心方法是针对所有XML的,针对HTML DOM有特殊的方法,如
使用DOM core:oImg.setAttribute("src", "picture.gif");
使用HTML DOM:oImg.src = "picture.jpg";
附件是javascript dom 手册,可以方便查阅
- jsdom_all.rar (193.8 KB)
- 下载次数: 2021
评论
[*]
谢谢楼主啦!!辛苦了!!!!
发表评论
-
如何去掉链接虚线框
2011-10-08 13:58 1715链接的虚线框影响整体风格,我们在工作经常会将它去掉,而采用 ... -
Javascript获得当前地址栏url
2011-02-24 10:36 1389URL即:统一资源定位符 (U ... -
文字滚动
2009-10-24 09:51 1356三种文字滚动效果: 向上滚动 类似marque ... -
会动的眼睛
2009-07-09 23:31 1657<style type="text/css ... -
页面输出时一些常用的小技巧(二)
2009-05-16 22:42 1264页面输出时一些常用的 ... -
keycode值和chr码值
2009-01-09 14:44 2441keycode 8 = BackSpace BackSp ... -
展示图片的例子1
2008-12-01 17:08 1429很炫的展示图片的效果,用纯javascript写的,逻 ... -
二级菜单事件
2008-11-19 23:34 1101<!DOCTYPE html PUBLIC " ... -
删除空白子节点
2008-11-19 20:57 1805<!DOCTYPE html PUBLIC " ... -
分页效果
2008-04-17 18:40 1486还不错的分页效果,暂时用不上,收藏一下,见附件 -
动画效果打开关闭图层
2008-04-16 13:45 1778<html xmlns="http://www ... -
很炫的图片循环效果
2008-04-16 10:49 3849<!DOCTYPE HTML PUBLIC " ... -
实用的js动画
2008-04-03 17:06 3796<!DOCTYPE html PUBLIC " ... -
用js给input传值
2008-03-27 18:06 5486<style> #name{ float:left ... -
常用js语句——大全
2008-03-16 17:02 29421.document.write(""); ... -
用javascript来充实文档的内容
2008-03-06 18:35 1669<!DOCTYPE html PUBLIC " ... -
javascript美术馆改进版
2008-03-04 14:31 2070<!DOCTYPE html PUBLIC " ... -
javascript美术馆
2008-02-29 15:56 1319<!DOCTYPE html PUBLIC " ... -
js日历
2008-02-26 22:32 1628<html> <head> <t ... -
javascript的IE和Firefox兼容性问题
2008-02-25 22:12 1313以 IE 代替 Internet Explorer,以 MF ...
相关推荐
根据提供的文件信息,我们可以推断出这是一本关于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语法特性**: - **变量命名规则**:JavaScript变量名是大小写敏感的,变量名中不允许包含空格或大部分标点符号(美元符号"$"除外)。变量名可以包含字母、数字、美元符号和下划线。 - **数据类型**...
JavaScript Enlightenment可能详细讲解了这些基础知识,包括变量、数据类型、控制结构、函数、对象、数组、正则表达式等,并深入到ES6及后续版本的新特性,如箭头函数、Promise、async/await等。 DOM是HTML和XML...
从JavaScript的基础语法到对象、数组、闭包和原型链等高级特性,再到DOM编程的具体应用,每一步都紧贴实际开发的需求,每一个例子都经过精心设计,确保读者能够通过实际操作来加深理解。 JavaScript作为一种在...
书中的第二版更新了现代JavaScript语法和API的使用,如ES6的新特性,以及现代浏览器提供的DOM接口,如MutationObserver用于监听DOM变化。 本书内容可能包括以下几个方面: 1. JavaScript基础:介绍变量、数据类型...
通过学习《JavaScript DOM编程艺术》的源代码,读者不仅可以掌握基本的DOM操作,还能深入了解如何结合JavaScript的最新特性来构建现代、动态的Web应用程序。实践中遇到的问题和解决方案都可能成为提升技能的关键点。