您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關XML有哪些拓展,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
以下是對XML基礎的總結
初識
http://www.php.cn/
基礎
http://www.php.cn/
下面是對XML的拓展包括 XML屬性、驗證
XML 元素可以在開始標簽中包含屬性,類似 HTML。
屬性 (Attribute) 提供關于元素的額外信息。
從 HTML,你會回憶起這個:<img src="computer.gif">。"src" 屬性提供有關 <img> 元素的額外信息。
在 HTML 中(以及在 XML 中),屬性提供有關元素的額外信息:
<img src="computer.gif"> <a href="demo.asp">
屬性通常提供不屬于數據組成部分的信息。在下面的例子中,文件類型與數據無關,但是對需要處理這個元素的軟件來說卻很重要:
<file type="gif">computer.gif</file>
屬性值必須被引號包圍,不過單引號和雙引號均可使用。比如一個人的性別,person 標簽可以這樣寫:
<person sex="female">
或者這樣也可以:
<person sex='female'>
注釋:如果屬性值本身包含雙引號,那么有必要使用單引號包圍它,就像這個例子:
<gangster name='George "Shotgun" Ziegler'>
或者可以使用實體引用:
<gangster name="George "Shotgun" Ziegler">
請看這些例子:
<person sex="female"> <firstname>Anna</firstname> <lastname>Smith</lastname> </person> <person> <sex>female</sex> <firstname>Anna</firstname> <lastname>Smith</lastname> </person>
在第一個例子中,sex 是一個屬性。在第二個例子中,sex 則是一個子元素。兩個例子均可提供相同的信息。
沒有什么規矩可以告訴我們什么時候該使用屬性,而什么時候該使用子元素。我的經驗是在 HTML 中,屬性用起來很便利,但是在 XML 中,您應該盡量避免使用屬性。如果信息感覺起來很像數據,那么請使用子元素吧。
下面的三個 XML 文檔包含完全相同的信息:
第一個例子中使用了 date 屬性:
<note date="08/08/2008"> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note>
第二個例子中使用了 date 元素:
<note> <date>08/08/2008</date> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note>
第三個例子中使用了擴展的 date 元素(這是我的最愛):
<note> <date> <day>08</day> <month>08</month> <year>2008</year> </date> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note>
因使用屬性而引起的一些問題:
屬性無法包含多重的值(元素可以)
屬性無法描述樹結構(元素可以)
屬性不易擴展(為未來的變化)
屬性難以閱讀和維護
請盡量使用元素來描述數據。而僅僅使用屬性來提供與數據無關的信息。
不要做這樣的蠢事(這不是 XML 應該被使用的方式):
<note day="08" month="08" year="2008" to="George" from="John" heading="Reminder" body="Don't forget the meeting!"> </note>
有時候會向元素分配 ID 引用。這些 ID 索引可用于標識 XML 元素,它起作用的方式與 HTML 中 ID 屬性是一樣的。這個例子向我們演示了這種情況:
<messages> <note id="501"> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note> <note id="502"> <to>John</to> <from>George</from> <heading>Re: Reminder</heading> <body>I will not</body> </note> </messages>
上面的 ID 僅僅是一個標識符,用于標識不同的便簽。它并不是便簽數據的組成部分。
在此我們極力向您傳遞的理念是:元數據(有關數據的數據)應當存儲為屬性,而數據本身應當存儲為元素。
XML驗證
擁有正確語法的 XML 被稱為“形式良好”的 XML。
通過某個 DTD 進行了驗證的 XML 是“合法”的 XML。
一個"形式良好"的 XML 文檔擁有正確的語法。
一個"形式良好"的 XML 文檔會遵守前幾章介紹過的 XML 語法規則:
XML 文檔必須有根元素
XML 文檔必須有關閉標簽
XML 標簽對大小寫敏感
XML 元素必須被正確的嵌套
XML 屬性必須加引號
<?xml version="1.0" encoding="ISO-8859-1"?> <note> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note>
一個合法的 XML 文檔是"形式良好"的 XML 文檔,同樣遵守文檔類型定義 (DTD) 的語法規則:
<?xml version="1.0" encoding="ISO-8859-1"?><!DOCTYPE note SYSTEM "Note.dtd"><note> <to>George</to> <from>John</from> <heading>Reminder</heading> <body>Don't forget the meeting!</body> </note>
在上例中,DOCTYPE 聲明是對外部 DTD 文件的引用。下面的段落展示了這個文件的內容。
DTD 的作用是定義 XML 文檔的結構。它使用一系列合法的元素來定義文檔結構:
<!DOCTYPE note [ <!ELEMENT note (to,from,heading,body)> <!ELEMENT to (#PCDATA)> <!ELEMENT from (#PCDATA)> <!ELEMENT heading (#PCDATA)> <!ELEMENT body (#PCDATA)> ]>
有關DTD的總結:
http://www.php.cn/
<xs:element name="note"> <xs:complexType> <xs:sequence> <xs:element name="to" type="xs:string"/> <xs:element name="from" type="xs:string"/> <xs:element name="heading" type="xs:string"/> <xs:element name="body" type="xs:string"/> </xs:sequence> </xs:complexType> </xs:element>
XML 文檔中的錯誤會終止你的 XML 程序。
W3C 的 XML 規范聲明:如果 XML 文檔存在錯誤,那么程序就不應當繼續處理這個文檔。理由是,XML 軟件應當輕巧,快速,具有良好的兼容性。
如果使用 HTML,創建包含大量錯誤的文檔是有可能的(比如你忘記了結束標簽)。其中一個主要的原因是 HTML 瀏覽器相當臃腫,兼容性也很差,并且它們有自己的方式來確定當發現錯誤時文檔應該顯示為什么樣子。
使用 XML 時,這種情況不應當存在。
為了幫助您對 XML 進行語法檢查,我們創建了一個 XML 驗證器。
把您的 XML 粘貼到下面的文本框中,然后點擊"驗證"按鈕來進行語法檢查。
只要把 DOCTYPE 聲明添加到您的 XML 中,然后點擊驗證按鈕即可:
注釋:只有在 Internet Explorer 中,可以根據 DTD 來驗證 XML。Firefox, Mozilla, Netscape 以及 Opera 做不到這一點。
如何將XML顯示在Html上:
從 XML 文件中加載數據,然后把數據顯示為一個 HTML 表格
在上一節中,我們講解了如何通過 JavaScript 來解析 XML 并訪問 DOM。
本例遍歷一個 XML 文件 (cd_catalog.xml),然后把每個 CD 元素顯示為一個 HTML 表格行:
<html> <body> <script type="text/javascript"> var xmlDoc=null; if (window.ActiveXObject) {// code for IExmlDoc=new ActiveXObject("Microsoft.XMLDOM"); } else if (document.implementation.createDocument) {// code for Mozilla, Firefox, Opera, etc.xmlDoc=document.implementation.createDocument("","",null); } else { alert('Your browser cannot handle this script'); } if (xmlDoc!=null) { xmlDoc.async=false; xmlDoc.load("cd_catalog.xml"); document.write("<table border='1'>"); var x=xmlDoc.getElementsByTagName("CD"); for (i=0;i<x.length;i++) { document.write("<tr>"); document.write("<td>"); document.write( x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue); document.write("</td>"); document.write("<td>"); document.write( x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue); document.write("</td>"); document.write("</tr>"); } document.write("</table>"); } </script> </body> </html>
檢測瀏覽器,然后使用合適的解析器來加載 XML
創建一個 HTML 表格(<table border="1">)
使用 getElementsByTagName() 來獲得所有 XML 的 CD 節點
針對每個 CD 節點,把 ARTIST 和 TITLE 中的數據顯示為表格數據
用 </table> 結束表格
XMLHttpRequest
XMLHttpRequest 對象是開發者的夢想,因為您能夠:
在不重新加載頁面的情況下更新網頁
在頁面已加載后從服務器請求數據
在頁面已加載后從服務器接收數據
在后臺向服務器發送數據
所有現代的瀏覽器都支持 XMLHttpRequest 對象。
實例:當鍵入文本時與服務器進行 XML HTTP 通信。
通過一行簡單的 JavaScript 代碼,我們就可以創建 XMLHttpRequest 對象。
在所有現代瀏覽器中(包括 IE 7):
xmlhttp=new XMLHttpRequest()
在 Internet Explorer 5 和 6 中:
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")
<script type="text/javascript"> var xmlhttp; function loadXMLDoc(url) { xmlhttp=null; if (window.XMLHttpRequest) {// code for all new browsers xmlhttp=new XMLHttpRequest(); } else if (window.ActiveXObject) {// code for IE5 and IE6 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } if (xmlhttp!=null) { xmlhttp.onreadystatechange=state_Change; xmlhttp.open("GET",url,true); xmlhttp.send(null); } else { alert("Your browser does not support XMLHTTP."); } } function state_Change() { if (xmlhttp.readyState==4) {// 4 = "loaded" if (xmlhttp.status==200) {// 200 = OK // ...our code here... } else { alert("Problem retrieving XML data"); } } } </script>
TIY
注釋:onreadystatechange 是一個事件句柄。它的值 (state_Change) 是一個函數的名稱,當 XMLHttpRequest 對象的狀態發生改變時,會觸發此函數。狀態從 0 (uninitialized) 到 4 (complete) 進行變化。僅在狀態為 4 時,我們才執行代碼。
我們的實例在 open() 的第三個參數中使用了 "true"。
該參數規定請求是否異步處理。
True 表示腳本會在 send() 方法之后繼續執行,而不等待來自服務器的響應。
onreadystatechange 事件使代碼復雜化了。但是這是在沒有得到服務器響應的情況下,防止代碼停止的最安全的方法。
通過把該參數設置為 "false",可以省去額外的 onreadystatechange 代碼。如果在請求失敗時是否執行其余的代碼無關緊要,那么可以使用這個參數。
XML實例:
請看下面這個 XML 文檔 ( "cd_catalog.xml" ),它描述了一個 CD 目錄:
<?xml version="1.0" encoding="ISO-8859-1"?> <CATALOG> <CD> <TITLE>Empire Burlesque</TITLE> <ARTIST>Bob Dylan</ARTIST> <COUNTRY>USA</COUNTRY> <COMPANY>Columbia</COMPANY> <PRICE>10.90</PRICE> <YEAR>1985</YEAR> </CD> . . ... more ... .
為了加載 XML 文檔 (cd_catalog.xml),我們使用了與 XML 解析器那一節中相同的代碼:
var xmlDoc; if (window.ActiveXObject) { // code for IE xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); } else if (document.implementation.createDocument) { // code for Firefox, Mozilla, Opera, etc. xmlDoc=document.implementation.createDocument("","",null); } else { alert('Your browser cannot handle this script'); } xmlDoc.async=false; xmlDoc.load("cd_catalog.xml");
在本代碼執行后,xmlDoc 成為一個 XML DOM 對象,可由 JavaScript 訪問。
以下代碼使用來自 XML DOM 對象的數據來填充一個 HTML 表格:
document.write("<table border='1'>"); var x=xmlDoc.getElementsByTagName("CD"); for (var i=0;i<x.length;i++) { document.write("<tr>"); document.write("<td>"); document.write( x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue); document.write("</td>"); document.write("<td>"); document.write( x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue); document.write("</td>"); document.write("</tr>"); } document.write("</table>");
針對 XML 文檔中的每個 CD 元素,會創建一個表格行。每個表格行包含兩個表格數據單元,其中的數據來自當前 CD 元素的 ARTIST 和 TITLE。
XML 數據可以拷貝到任何有能力顯示文本的 HTML 元素。
下面的代碼為 HTML 文件的 <head> 部分。這段代碼從第一個 <CD> 元素中獲得 XML 數據,然后在 id="show" 的 HTML 元素中顯示數據:
var x=xmlDoc.getElementsByTagName("CD"); i=0; function display() { artist= (x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue); title= (x[i].getElementsByTagName("TITLE")[0].childNodes[0].nodeValue); year= (x[i].getElementsByTagName("YEAR")[0].childNodes[0].nodeValue); txt="Artist: "+artist+"<br />Title: "+title+"<br />Year: "+year; document.getElementById("show").innerHTML=txt; }
HTML 的 body 元素包含一個 onload 事件屬性,它的作用是在頁面已經加載時調用 display() 函數。body 元素中還包含了供接受 XML 數據的 <p id='show'> 元素。
<p id='show'></p> </body>
通過上例,你只能看到來自 XML 文檔中第一個 CD 元素中的數據。為了導航到數據的下一行,必須添加更多的代碼。
為了向上例添加導航(功能),需要創建 next() 和 previous() 兩個函數:
function next() { if (i<x.length-1) { i++; display(); } } function previous() { if (i>0) { i--; display(); } }
next() 函數確保已到達最后一個 CD 元素后不顯示任何東西,previous () 函數確保已到達第一個 CD 元素后不顯示任何東西。
通過點擊 next/previous 按鈕來調用 next() 和 previous() 函數:
<input type="button" onclick="previous()" value="previous" /> <input type="button" onclick="next()" value="next" />
上述就是小編為大家分享的XML有哪些拓展了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。