如前所述,类中的%XML.TextReader
解析XML文档并创建一个text reader
对象,该对象由一组与文档组件相对应的节点组成;节点类型在本章前面的“文档节点”中进行了描述。
当将焦点更改到其他节点时,text reader
对象的属性将更新,以包含有关当前检查的节点的信息。本节介绍类中%XML.TextReader
的所有属性。
如果当前节点是元素或属性,则此属性指示元素的属性数。在给定元素中,第一个属性编号为1。对于任何其他类型的节点,此属性为0
。
指示文档中当前节点的深度。根元素位于深度1;根元素之外的项位于深度0
。请注意,属性与其所属元素的深度相同。同样,错误或警告与导致错误或警告的项的深度相同。
如果读取器已到达源文档的末尾,则为true;否则为false。
如果当前节点是一个元素,则如果该元素具有属性,则此属性为true(如果没有属性,则为false)。如果当前节点是属性,则此属性为true。对于任何其他类型的节点,此属性为False。
如果当前节点是具有值的节点类型(即使该值为空),则为True。否则,此属性为false。具体地说,对于以下类型的节点,此属性为真:
请注意,对于ERROR
和WARNING
类型的节点,HasValue
为false
,即使这些节点类型具有值。
如果当前节点是元素且为空,则为True。否则,此属性为false。
对于Attribute
、Element
或EndElement
类型的节点,这是当前元素或属性的名称,不带命名空间前缀。对于所有其他类型的节点,此属性为NULL
。
当前节点的完全限定名称,视节点类型而定。下表提供了详细信息:
节点名称(按类型)
groupID="GX078"
,则Name
为:groupID
<s01:Person groupID="GX078">...</s01:Person>
则Name
为: s01:Person
entity
实体的名称。xmlns:s01="http://www.root.org"
则Name
为s01
另一个例子,如果名称空间声明如下:xmlns="http://www.root.org"
Name
为空。processinginstruction
处理指令的目标。
例如,如果处理指令是: <?xml-stylesheet type="text/css" href="mystyles.css"?>
则Name
为xml-stylesheet
对于attribute、element或endelement类型的节点,这是属性或元素所属的命名空间(如果有的话)。 对于所有其他类型的节点,此属性为空。
当前节点的类型。
元素的路径。例如,以下XML文档:
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/css" href="mystyles.css"?>
<s01:Root xmlns:s01="http://www.root.org" xmlns="www.default.org">
<Person>
<Name>Willeke,Clint B.</Name>
<DOB>1925-10-01</DOB>
<GroupID>U3577</GroupID>
<Address xmlns="www.address.org">
<City>Newton</City>
<Zip>56762</Zip>
</Address>
</Person>
</s01:Root>
对于City
元素,Path
属性是/s01:root/Person/Address/City
。其他元素也被类似地对待。
指示文本阅读器对象的总体状态,以下值之一:
“Initial”
意味着Read()
方法还没有被调用。“Interactive”
意味着Read()
方法至少被调用过一次。“EndOfFile”
表示已经到达文件的末尾。值(如果有的话),适合于节点类型。具体情况如下表所示:
节点的值,按类型
groupID=“GX078”
则值为:GX078
he content of the text node. For example, if an element is
:
<DOB>1925-10-01</DOB>
;,则对于字符节点,值为:1925-10-01
Comment here
<?xml-stylesheet type="text/css" href="mystyles.css"?>
则值为 type="text/css" href="mystyles.css"?
xmlns:s01="http://www.root.org"
,则值为:s01 http://www.root.org
null
文档中此节点的序列号。第一个节点编号为1。请注意,属性与其所属的元素具有相同的序列号。
要指定文档源,请使用文本阅读器的ParseFile()
、ParseStream()
、ParseString()
或ParseURL()
方法。在任何情况下,源文档都必须是格式良好的XML文档;也就是说,它必须遵守XML语法的基本规则。对于这些方法,只需要前两个参数。作为参考,这些方法按顺序有以下参数:
请注意,对于ParseFile(),Filename参数只能包含ASCII字符。
$OK
,则作为输出参数返回。提示:对于%XML.TextReader
的解析方法,默认掩码是$SAXCONTENTEVENTS
。请注意,这会忽略注释。要解析所有可能的节点类型,请对此参数使用$$$SAXALLEVENTS
。请注意,这些宏在%occSAX.inc
包含文件中定义。
"namespace URL,namespace URL"
这里,Namespace
是用于模式的XML名称空间,URL是提供模式文档位置的URL。名称空间和URL值之间有一个空格字符。
ParseURL()
方法)Web服务器的请求,作为%Net.HttpRequest
的实例。默认情况下,系统会创建%Net.HttpRequest
的新实例并使用该实例,但也可以使用%Net.HttpRequest
的其他实例发出请求。这在已经设置了代理和其他属性的预先存在的%Net.HttpRequest
的情况下很有用。此选项仅适用于http
类型的URL
(例如,不适用于file
或ftp
)。本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有