內(nèi)建的 DOM 解析器使在 PHP 中處理 XML 文檔成為可能。
W3C DOM 提供了針對 HTML 和 XML 文檔的標(biāo)準(zhǔn)對象集,以及用于訪問和操作這些文檔的標(biāo)準(zhǔn)接口。
W3C DOM 被分為不同的部分 (Core, XML 和 HTML) 和不同的級別 (DOM Level 1/2/3):
如果您希望學(xué)習(xí)更多有關(guān) XML DOM 的知識,請?jiān)L問我們的 XML DOM 教程。
如需讀取和更新 - 創(chuàng)建創(chuàng)建并處理 - 一個(gè) XML 文檔,您需要 XML 解析器。
有兩種基本的 XML 解析器類型:
DOM 解析器是基于樹的解析器。
請看下面的 XML 文檔片段:
<?xml version="1.0" encoding="ISO-8859-1"?> <from>John</from>
XML DOM 把 XML 視為一個(gè)樹形結(jié)構(gòu):
DOM XML 解析器函數(shù)是 PHP 核心的組成部分。無需安裝就可以使用這些函數(shù)。
將在我們的例子中使用下面的 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,并把它輸出:
<?php $xmlDoc = new DOMDocument(); $xmlDoc->load("note.xml"); print $xmlDoc->saveXML(); ?>
以上代碼的輸出:
George John Reminder Don't forget the meeting!
假如您在瀏覽器窗口中查看源代碼,會看到下面這些 HTML:
<?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>
上面的例子創(chuàng)建了一個(gè) DOMDocument-Object,并把 "note.xml" 中的 XML 載入這個(gè)文檔對象中。
saveXML() 函數(shù)把內(nèi)部 XML 文檔放入一個(gè)字符串,這樣我們就可以輸出它。
我們要初始化 XML 解析器,加載 XML,并循環(huán) <note> 元素的所有元素:
<?php $xmlDoc = new DOMDocument(); $xmlDoc->load("note.xml"); $x = $xmlDoc->documentElement; foreach ($x->childNodes AS $item) { print $item->nodeName . " = " . $item->nodeValue . "<br />"; } ?>
以上代碼的輸出:
#text = to = George #text = from = John #text = heading = Reminder #text = body = Don't forget the meeting! #text =
在上面的例子中,您看到了每個(gè)元素之間存在空的文本節(jié)點(diǎn)。
當(dāng) XML 生成時(shí),它通常會在節(jié)點(diǎn)之間包含空白。XML DOM 解析器把它們當(dāng)作普通的元素,如果您不注意它們,有時(shí)會產(chǎn)生問題。
如果您希望學(xué)習(xí)更多有關(guān) XML DOM 的知識,請?jiān)L問我們的 XML DOM 教程。
如對本文有疑問,請?zhí)峤坏浇涣髡搲?,廣大熱心網(wǎng)友會為你解答!! 點(diǎn)擊進(jìn)入論壇
Powered by 365建站網(wǎng) RSS地圖 HTML地圖
copyright © 2013-2024 版權(quán)所有 鄂ICP備17013400號