1.XML基础
2.XML语法3.XML DOM4.Javascript解析XML文档1.XML基础eXtensible Markup Language 可扩展标记语言XML是一种平台无关的用于携带和传送数据的方法。~~~~xml主要是描述数据是什么,一般没有数据如何呈现的信息,有别于HTML,HTML可以说是xml的一种实现。(注:xhtml才是xml的一种实现)xml文档可以用IE 文本编辑器或者专门的XML编辑器浏览~~~xml不同平台的数据交换,但不适合大批量数据的存储与处理(有别于数据库)多个xml文档的元素之间还可以定义主外键关系xml优点:~~~通用性,可扩展性,自我描述性xml的用途~~作为一种通用的数据格式,存储和交换数据;用作配置文件2.XML语法XML文档声明XML处理指令XML元素(元素 元素属性 元素内容)<?xml version="1.0" encoding="utf-8" ?> <!--xml文档声明--><?xml-stylesheet type="text/xsl" href="mystyle.xsl" ?><!--xml处理指令 可选--><stu-roster> <!--xml元素--> <student> <id>A001</id> <name>dingdang</name> </student> <student> <id>A009</id> <name>kitty</name> <student></stu-roster>~~~XML文档声明 必须包含version属性,其他属性如下 顺序不能打乱。<?xml version="1.0" encoding="utf-8" standalone="yes" ?>XML处理指令为处理XML文档的应用程序提供提示信息XML解析器会把处理指令原封不动的传给处理程序,由处理应用程序按照指令的提示信息进行处理使用格式显示XML文档用CSS定义外观样式或者用XSL定义外观 Xml Stylesheet Language 后者功能更强大XML元素: 起始标识 结束标记 属性 内容<title>雾都孤儿</title>XML所有元素都必须有结束标记。标签名区分大小写,开始标签和结束标签要匹配
元素内容:元素包含子元素元素直接包含内容元素没有任何内容 空标记根元素:没有嵌套在其他元素内的元素 最高层元素文档内所有元素都是根元素的子孙元素。根元素要有且仅有一个元素内容CDATA Character DATA 字符数据指定不想被解析程序解析的一片原始数据区。PCDATA Parsed Character DATA 由XML解析器解析的字符数据CDATA例子:<![CDATA[...anything can go here...]]>CDATA区内不能出现字符"]]>"可以在CDATA区内嵌入其他语言的代码,如javascript等。PCDATA区 PCDATA 需要被XML解析器解析的字符数据直接写在起始标记和结束标记之间的内容。字符转义
有些特殊字符不能出现在PCDATA区内,需要用字符实体替代,如 < &等< <> >& & ampersand&apo ' apostrophe" "XML注释 同HTML <!-- comment -->xml文档声明必须是第一行代码,注释不能放在XML文档声明之前。3.XML DOM DOM 是所有浏览器都支持的一种标准,它定义了一组与浏览器和编程语言都无关的标准对象,利用这些对象模型可以方便地操作XML文档DOM是最为流行的XML文档访问方式。DOM的优缺点:一般使用DOM时,把所有XML文档信息都存放在内存,遍历容易,但是内存占用高,解析较慢DOM树形结构 XML文档的每个成分都看作是一个节点。节点类型:Document 根节点 9DocumentType DTD引用的对象的表现形式 10Element 元素节点 1Attr 属性节点 2Text 文本节点 3CDataSection 字符数据节点 4Comment 注释节点 8DOM树形结构中,节点间的关系:parent child sibling4.javascript解析XML文档XML DOM的属性和方法 javascript操纵XML DOM现在大多数的浏览器都支持XMLIE和Mozilla的浏览器都通过javascript提供对XML的支持javascript处理XML文档的基础是DOM树形结构在javascript中有关于DOM的API,在这些API中定义了DOM的属性和方法。利用javascript中的DOM API可以实现对XML文档的访问、创建、删除,修改等操作。用javascript处理XML文档是ajax技术的核心javascript处理XML文档的工作原理:1.创建XML DOM对象2.载入XML文档的内容3.调用javascript关于XML DOM的属性和方法进行处理。创建XML DOM对象 IE和非IE浏览器创建方法不同IE用ActiveX插件中的 MSXML库实现对XML的支持var xmlDom=new ActiveXObject(aVersion);aVersion的取值可以是 Microsoft.XMLDOMMSXML2.DOMDocumentMSXML2.DOMDocument3.0MSXML2.DOMDocument4.0MSXML2.DOMDocument5.0MSXML2.DOMDocument6.0如:var xmlDom=new ActiveXObject("MSXML2.DOMDocument6.0");IE支持2中载入XML文档的方法:load()和loadXML()var xmlDoc=xmlDom.load(url); //默认采用异步的方式载入XML文档数据//同步方式载入XML文档数据xmlDom.async=false;var xmlDoc=xmlDom.load(url);var xmlDoc=xmlDom.loadXML(sXml); //sXML为XML格式的字符串Firefox下获得XML DOM对象在Firefox浏览器中需要调用document.inplementation对象的createDocument()方法创建一个XML DOM对象。var xmlDom=document.inplementation.createDocument("","",null);Firefox浏览器只支持load()方法载入XML文档。var xmlDoc=xmlDOM.load("test.xml");获取XML DOM对象--跨浏览器兼容的方法,使用zXML库实现跨浏览器对XML的支持。var xmlDom=zXMLDom.createDocument();zXML支持2中方法载入XML文档,同IE. xmlDom.load(),xmlDom.loadXML();>>>>操作XML文档<<<<<节点的属性:nodeTypenodeNamenodeValueattributes 元素节点的属性节点导航firstChildlastChildchildNodespreviousSibling 前一个兄弟节点nextSibling 下一个兄弟节点documentElement 指向XML文档的根节点,只有Document对象有该属性。Document.documentElementowerDocument 指向这个节点所属文档。XML DOM的方法:创建节点:createElement(tagName) 创建标签名为tagName的元素。createTexNode(text) 创建文本节点createAttribute(attrname) 创建一个属性节点 属性未赋值createDocumentFragment() 创建文档碎片节点createProcessingInstruction(target,data);读取节点:getElementByTagName(tagname) //返回标签名为tagname的nodelistgetAttribute(attrname) //获取当前节点中 属性名为attrname的属性值setAttribute(attrname,attrvalue) 设置属性节点的值setAttributeNode(attrNode) 某节点属性节点列表的尾部添加一个属性节点。添加删除节点的方法:appendChild(node);removeChild(node)replaceChild(newNode,oldNode)insertBefore(newNode,oldNode);