目前,許多Web網站的內容資料都存放在資料庫或資料檔案中。對於Web程式開發人員來說,如果要想把有用的資訊從資料庫中提取出來,傳統的方法是在伺服器端編寫腳本程式(如VBScript、javaScript、CGI、asp、Perl等等),透過對資料庫執行SQL查詢得到相關記錄,然後把查詢結果組織成HTML頁面回傳給客戶端,使用者使用瀏覽器觀察最終結果。
為了提升系統服務的彈性、可擴充性,使服務對象範圍更廣,許多商業網站都盡可能地把商務規則、原始資料和表現形式當作相互獨立的服務分別提供。 HTML那種蘊涵資料於顯示的方式顯然不合乎這種需求。因此,把原始資料存放在XML文件中,使用樣式單檔顯示內容是XML技術適合電子商務的優勢所在。但從本質上來說,XSL技術不是以資料顯示的,它是一種格式轉換技術,在顯示手段和方式上都遠不如HTML那麼豐富。對程式設計人員來說,較為理想的方案是把HTML和XML兩種技術結合,優勢互補,讓真正的原始資料在能維持本來意義和結構的同時,還能充分利用HTML那千變萬化的顯示技巧。 XML資料島就是這種技術融合的產物,它使用d9612f61437e20b5df317e4aa7a27021標籤把XML資料直接嵌入HTML頁面中,從而實現了二者的優勢互補。
IE中資料島的處理方式
為了能夠處理這種內嵌XML程式碼的HTML頁面,Internet Explorer 4.0(以下簡稱IE 4.0)引進了DSO(Data Source Objects,資料來源物件)技術,用Java Applet實作。
例如:
<APPLET CODE=“com.ms.xml.dso.XMLDSO.class” ID=“xmldso” WIDTH=0 HEIGHT=0 MAYSCRIPT=TRUE> <PARAM NAME=“URL” VALUE=“myXML.xml”> </APPLET>
在上述範例中,CODE屬性指明了DSO Java小程序,MAYSCRIPT屬性保證用戶端腳本能夠處理資料對象,PARAM標籤指明了XML文件的位置。
使用Java的限制在於只能在HTML文件中說明XML的URL位址,而不能直接將XML標籤嵌入其中,這就和真正的資料島方案還有一定的差距。微軟在Internet Explorer 5.0(以下簡稱IE 5.0)中對DSO技術進行了擴展,突破了以往的限制,使HTML和XML真正地融合到了一起。 HTML頁面中支援直接使用d9612f61437e20b5df317e4aa7a27021標籤。
例如:
<HTML> <XML ID=“xmldso”> <?xml version=“1.0”?> some XML…… </XML>
只要保證每個資料島的ID都是唯一的,就可以在頁面中的任何必要的地方嵌入資料島,並且這些DSO彼此都是互相獨立的。
除了上面範例中的這種直接嵌入方式,還可以使用外部引用方式連結資料島。
例如:
<XML ID=“xmldso” SRC=“myXML.xml”> </XML>
這樣,只有當公司的客戶物件繼續使用IE 4.0,並且為了解決這部分客戶的兼容性問題時,Java Applet才是程式設計人員要考慮的選擇方案。
在IE 5.0所實現的DSO技術中,如果資料是透過SQL語言查詢資料庫得到的結果,那麼就把它們存放在ADO(ActiveX Data Objects)記錄集中。伺服器把這種ActiveX控制項(通常是ADO記錄集)送到客戶端,由客戶端腳本程式做進一步的處理。實際上,IE 5.0就是把XML資料島當作一種特殊的ADO記錄集來處理的。
XML的資料綁定
1. ADO記錄集的對應
XML中的每一條主元素都被對應為ADO記錄集中的一筆記錄,而子元素則會相應地被對應到記錄集中的欄位(也稱為域)。
例如,存在XML資料島books.xml如下:
<XML ID=“xmldso”> <?xml version=“1.0”?> <booklist> <book> <title>Straight Talk About Computers</title> <isbn>72-80088-005</isbn> </book> <book> <title> Gourmet Microwave </title> <isbn>72-80081-082</isbn> </book> </booklist> </XML>
此時,映射後的ADO記錄集為:
title isbn
Straight Talk About Computers 72-80088-005
Gourmet Microwave 72-80081-082
#2.與HTML元素的綁定
在HTML文件中嵌入資料島之後,就可以將XML資料島與HTML元素綁定在一起。每一個DSO條目(即資料島)都有唯一的ID號。首先將HTML元素中的DATASRC屬性設定為對應的ID,就可以把HTML元素和資料島連結在一起。然後再透過設定DATAFLD屬性值,來確定所擷取的XML元素。
例如,與p元素綁定的程式碼如下:
<p ID=title DATASRC=#xmldso DATAFLD=“title”></p> <p ID=PRice DATASRC=#xmldso DATAFLD=“isbn”></p>
注意:並非所有的HTML元素都能與XML資料島綁定。目前,支援此DSO綁定機制的元素如下:
A、APPLET、BUTTON、p、FRAME、IFRAME、 IMG、INPUT (此處類型是:CHECKBOX、HIDDEN、 LABEL、PASSWord、RADIO和TEXT)、LABEL、 MARQUEE、SELECT、SPAN、TABLE和TEXTAREA。
3.以表格方式明確XML資料
若把XML資料與TABLE元素綁定在一起,就可以自動地顯示為多行的表格形式。
例如,XML資料與TABLE元素綁定的程式碼如下:
<TABLE BORDER=1 DATASRC=“#xmldso”> <THEAD> <TR><TH>Title</TH> <TH>ISBN</TH></TR> </THEAD> <TBODY> <TR><TD><p DATAFLD=“title”></p></TD> <TD><p DATAFLD=“isbn”> </p></TD></TR> </TBODY> 1 </TABLE>
这样,通过将TABLE元素中的DATASRC属性设定为#xmldso,把两者绑定起来。表格内部分为表头(THEAD)和表体(TBODY)两部分。每一个463aef0d2da08708f472268a99530dbe元素都会显示为一行表格,具体每一栏显示哪一项数据,则由p元素中的DATAFLD属性指定。
以上是HTML與XML之間的優勢互補(上)的詳細內容。更多資訊請關注PHP中文網其他相關文章!