如何創建XML

 

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

 

1.如何生成XML數據

我們通過ASP或其他動態編程語言,最終需要的是XML格式的數據,這點和XML數據所在的文件載體無關,它可以是實實在在的XML文件,比如:http://www.dw8.cn/common/dw8.xml 。也可以爲asp文檔,比如:http://www.cnbruce.com/blog/rss2.asp,他們都是XML數據的體現,爲了實現XML數據的動態,所以需要使用到動態編程語言,比如ASP來實現生成它。

2.二,如何生成動態的XML文檔

如果是生成XML文件,介於動態文檔是ASP格式的,所以必須藉助FSO進行XML文件的生成,比如:

 

  1. <%
  2. XMLfile=server.mappath("test1.xml")
  3. Set fso = CreateObject("Scripting.FileSystemObject")
  4. Set MyFile = fso.CreateTextFile(XMLfile,True)
  5. MyFile.WriteLine("<?XML version=""1.0"" encoding=""gb2312""?>")
  6. MyFile.WriteLine("<世界>")
  7. MyFile.WriteLine("<你好>hello,world</你好>")
  8. MyFile.WriteLine("</世界>")
  9. MyFile.Close
  10. %>
  11. <a href="test1.XML">查看XML文件內容</a>

如果按照生成動態的

XML數據文件來說,則是將MyFile.WriteLine的相關內容在動態文檔中通過程式的手段來控制XML節點的名稱和值即可。

三,如何使用動態文檔生成XML數據

那如果不是生成XML文件,直接在動態文檔上輸出XML數據呢,須聲明文件的類型(即Response.ContentType

<%Response.ContentType = "text/XML"%>

比如直接瀏覽如下的動態ASP文檔,在瀏覽器中下則顯示爲XML數據樹

 

  1. <%
  2. With Response
  3.     .ContentType = "text/XML"
  4.     .write("<?XML version=""1.0"" encoding=""gb2312""?>")
  5.     .write("<世界>")
  6.     .write("<你好>hello,world</你好>")
  7.     .write("</世界>")
  8. End with
  9. %>

生成的

XML文件,其優勢就是處理該XML數據的文檔可以是靜態文檔,比如HTML文件通過JavaScriptXMLDOM來解析XML,同時也易於數據的保留,而動態文檔上的動態XML數據則沒有這樣有點。不過,在如今動態文檔無處不在用的時代,似乎這個優勢對於一些應用來說是無甚影響,甚至來說,動態文檔的XML數據流反而更具優勢:更及時、更動態。

四,生成XML數據就是這樣行了嗎?

無論是通過生成具體的XML文件,還是動態的XML數據流,只要按照XML的格式輸出相關XML節點和值就可以了,這樣看來XML似乎很簡單。但這並沒有真正接觸到XML的操作。在我們看來,這些XML無非就是一些成對的標籤和相關字符組成的數據記錄,毫無生命力可言。然而事實上,通過XMLDOM來操作XML則顯示了XML的絕對優勢(這點在生成XML時優勢不明顯,卻在添加、刪除XML節點時體驗無限)。

使用XMLDOM創建XML文檔,可使用Save方法生成XML文檔,使用createElement方法創建XML元素、createNode創建節點,其實對於XML中的任何標籤的創建都可以任意選擇其中的一種,不過一般使用createElement創建頂層(根)元素,使用createNode創建子節點(元素),當然createElementcreateNode的使用方法也是不同。

 

  1. <%
  2. Set objXMLdoc = CreateObject("Microsoft.XMLDOM")
  3. Set world=objXMLdoc.createElement("世界")
  4. objXMLdoc.appendChild(world)
  5. Set hello=objXMLdoc.createNode("element""你好""")
  6. hello.Text = "hello,world"
  7. objXMLdoc.documentElement.appendChild(hello)
  8. objXMLdoc.Save Server.MapPath("test2.xml")
  9. Set objXMLdoc = Nothing
  10. %>

CreateObject("Microsoft.XMLDOM")

聲明使用XMLDOM對象

在元素或節點被建立(createElementcreateNode)時,其並沒有加到文件樹中,若要將節點加到文件樹中,則需要插入,如appendChild

XMLDocument.createNode(type, name, nameSpaceURI) 表示建立一個指定型態、名稱,及命名空間的新節點

type 用來確認要被建立的節點型態,name 是一個字符串來確認新節點的名稱,命名空間的前綴則是選擇性的。nameSpaceURI 是一個定義命名空間URI 的字符串。如果前綴被包含在名稱參數中,此節點會在nameSpaceURI 的內文中以指定的前綴建立。如果不包含前綴,指定的命名空間會被視爲預設的命名空間。

objXMLdoc.createNode("element", "你好", "") 等同於 objXMLdoc.createElement("你好")

objXMLdoc.documentElement.appendChild(hello)其實就是XML文檔根元素下建立節點,在本例中等同於 world.appendChild(hello)world爲本例中的節點名,以此類推。

所以可以這樣來寫:

 

  1. <%
  2. Set objXMLdoc = CreateObject("Microsoft.XMLDOM")
  3. Set world=objXMLdoc.createElement("世界")
  4. objXMLdoc.appendChild(world)
  5. Set hello=objXMLdoc.createElement("你好")
  6. hello.Text = "hello,world"
  7. world.appendChild(hello)
  8. objXMLdoc.Save Server.MapPath("test2.xml")
  9. Set objXMLdoc = Nothing
  10. %>

需要注意的是,通過

XMLDOM生成的XML文件都是UTF-8格式的,這對我們所有應用程序文件的UTF-8化作了很好的推介。

總結

生成XML數據,可以使用FSO,如FSO被禁用,可使用XMLDOM,當然還可以直接使用動態文檔。不過如果融會貫通地掌握XML的操作,XMLDOM操作是必須的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章