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 代表一个实体引用,例如&quot;。这个节点类型不能包含子节点
    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里面
posted on 2008-01-21 18:05  Liu Jian  阅读(252)  评论(0编辑  收藏  举报