DOM(一) 基础

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里面

转载于:https://www.cnblogs.com/joeliu/archive/2008/01/21/1047636.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值