在TinyXML中,根据XML的各种元素来定义了一些类:
tixmlBase:整个TinyXML模型的基类。
tixmlAttribute:对应于XML中的元素的属性。
tixmlNode:对应于DOM结构中的节点。
tixmlComment:对应于XML中的注释。
tixmlDeclaration:对应于XML中的申明部分,即<?versiong="1.0" ?>。
tixmlDocument:对应于XML的整个文档。
tixmlElement:对应于XML的元素。
tixmlText:对应于XML的文字部分。
tixmlUnkNown:对应于XML的未知部分。
tixmlHandler:定义了针对XML的一些操作。
例如:
<!–Ourtodolistdata–>
<Todo>
<Itempriority="1">Gotothe<bold>Toystore!</bold></Item>
<Itempriority="2">dobills</Item>
</Todo>
整个对象树:
tixmlDocument "demo.xml"
tixmlDeclaration "version=’1.0′" "standalone=no"
tixmlComment " Our to do list data"
tixmlElement "Todo"
tixmlElement "Item" Attribtutes: priority = 1
tixmlText "Go to the "
tixmlElement "bold"
tixmlText "Toy store!"
tixmlElement "Item" Attributes: priority=2
tixmlText "Do bills"
在tinyXML中,用FirstChild("名字")查找节点时,调用FirstChild函数的节点与要查找的节点必须成“父子关系”。
句柄
想要健壮地读取一个XML文档,检查方法调用后的返回值是否为null是很重要的。一种安全的检错实现可能会产生像这样的代码:
if (root)
{
tixmlElement*element=root->FirstChildElement("Element");
if(element)
{
tixmlElement*child=element->FirstChildElement("Child");
if(child)
{
tixmlElement*child2=child->NextSiblingElement("Child");
if(child2)
{
//Finallydosomethinguseful.
用句柄的话就不会这么冗长了,使用tixmlHandle类,前面的代码就会变成这样:
tixmlHandledocHandle(
&
document);
tixmlElement
*
child2
=
docHandle.FirstChild(
"
Document
"
).FirstChild(
"
Element
"
).Child(
"
Child
"
,
1
).toElement();
if
(child2)
{
dosomethinguseful