DOM(Document Object Model):文檔對(duì)象模型。核心思想是:把 xml文件看作是一個(gè)對(duì)象模型,然后通過(guò)對(duì)象的方式來(lái)操作 xml 文件。
php對(duì)xml文檔進(jìn)行增刪改查(curd)操作,具體分析如下:
xml文檔:class.xml
代碼如下:<?xml version="1.0" encoding="utf-8"?>
class.xml 對(duì)應(yīng)的 DOM 樹(shù)結(jié)構(gòu)圖

php文件(對(duì)xml文檔操作)
查詢操作案例:
代碼如下:<?php
//3.2 讀取第一個(gè)學(xué)生
$stu1 = $students->item(0);//讀取到第一個(gè)學(xué)生。返回值為DOMElement對(duì)象。直接 echo $stu1->nodeValue;則把name,sex,age都輸出。
//3.3 取出第一個(gè)學(xué)生的名字
$stu1_name = $stu1->getElementsByTagName("name");
//3.4 讀取到名字
echo $stu1_name->item(0)->nodeValue;
?>
注意點(diǎn):
(1)編碼問(wèn)題;
(2)這里只是基礎(chǔ)演示,比較麻煩,后面用到循環(huán)和函數(shù)來(lái)操作;
(3)用var_dump(),查看變量的返回值是什么,再根據(jù)返回值到手冊(cè)中查找該返回值下的屬性與方法。
(4)整個(gè)順序下來(lái),getElementByTagName()并不需要一層一層的讀,事實(shí)上可以直接讀取到節(jié)點(diǎn)name的,而不需要先讀取student(當(dāng)然,如果同一個(gè)student下,有多個(gè)name,就會(huì)出問(wèn)題了,這里就需要學(xué)習(xí)新的知識(shí)點(diǎn)xpath)。
所以上面這代碼可以簡(jiǎn)單改為:
代碼如下:<?php新聞熱點(diǎn)
疑難解答