1.现在的XHTML都是符合XML规范的,XML里面
<? ?>包含的内容称为处理指令(processing instruction),它主要给XML解析器一些额外的信息,来告诉解析
器如何处理XML数据,例如所有的XML文件开头都有
<?xml version="1.0"?>
也可以指定XML文件的样式表
<?xml-stylesheet type="text/css"?>
2. DOM 节点的类型
Document
最顶层节点,所有的其它节点都是附属于它的。
DocumentType DTD引用(使用<!DOCTYPE>语法)的对象表示形式,例如:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">.
它不能包含子节点。
DocumentFragment 可以象Document一样保存其它节点。
Element 一对标签的内容。
Attr 标签里面的属性名称和属性值
Text 标签之间的文本或者CDataSection里面的文本
CDataSection
<![CDATA[ ]]>的对象表现形式
Entity
表示DTD中的一个实体定义,例如
<!ENTITY foo "foo">。这个节点类型不能包含子节点
EntityReference 代表一个实体引用,例如"。这个节点类型不能包含子节点
ProcessingInstruction 代表一个处理指令,例如:
<?xml-stylesheet type="text/css"?>
Comment XML注释,不能包含子节点
Notation 代表在DTD中定义的记号,很少用。
3. DOM操作函数
a. 对属性的操作,
getAttribute(),setAttribute(),removeAttribute(), 或者attributes.getNamedItem(), attributes.setNamedItem(),
attributes.removeNamedItem()
b. 对子节点的访问,
getElementsByTagName(), 可以传入"*"来获得所有的节点,但是这个结果和document.all是等价的
getElementsByName(), IE6和Opera7.5在这个方法上有些错误,它们还会返回id等于传入参数的Element,而且它们只检查<input/><img/>
元素
getElementById() id是唯一的,所以返回值最多只有一个Element,IE6对于这个方法有一个bug,如果传入参数匹配某个元素的name,它也
会返回这个元素
c. 创建和操作节点
createAttributge
createCDATASection
createComment
createDocumentFragment
createElement
createEntity
createProcessingInstruction
createTextNode
d. 增加节点常用方法:
createElement(),createTextNode(),appendChild(),使用这些方法的时候要注意,有些Element是不可以appendChild的。
e. 删除节点常用方法:
removeChild(), replaceChild(), insertBefore()
f. 如果操作的次数比较多,会导致多次刷新,这个时候可以使用
createDocumentFragment()函数创建document片段,整理好了,一次性的添加到document里面
转载于:https://www.cnblogs.com/joeliu/archive/2008/01/21/1047636.html