DefaultURI (XmlDoc/XmlNode function): Difference between revisions
m (1 revision) |
mNo edit summary |
||
Line 16: | Line 16: | ||
<tr><th>XPath</th> | <tr><th>XPath</th> | ||
<td>A <var>Unicode</var> string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (<i>nr</i>). | <td>A <var>Unicode</var> string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (<i>nr</i>). | ||
Prior to ''Sirius Mods'' version 7.6, this is an EBCDIC string.</td></tr> | |||
</table> | </table> | ||
==Example== | |||
In the following example, two elements are added along with their namespace | In the following example, two elements are added along with their namespace | ||
URIs, but only the second added element, which has no prefix, has a default | URIs, but only the second added element, which has no prefix, has a default | ||
namespace URI: | namespace URI: | ||
<p class="code">Begin | <p class="code">Begin | ||
%d | %d Object XmlDoc Auto New | ||
%n | %n Object XmlNode | ||
%n2 | %n2 Object XmlNode | ||
%n = %d:AddElement('p:top', , 'urn:top') | %n = %d:AddElement('p:top', , 'urn:top') | ||
%n2 = %n:AddElement('inner', , 'urn:default') | %n2 = %n:AddElement('inner', , 'urn:default') | ||
%n:Print | %n:Print | ||
Print 'URI of p:top default namespace =' And %n: | Print 'URI of p:top default namespace =' And %n:DefaultURI | ||
Print 'URI of inner default namespace =' And %n2: | Print 'URI of inner default namespace =' And %n2:DefaultURI | ||
End | End | ||
</p> | </p> | ||
The following lines are printed: | The following lines are printed: | ||
<p class="code"><p:top xmlns:p="urn:top"> | <p class="code"><nowiki><p:top xmlns:p="urn:top"> | ||
<inner xmlns="urn:default"/> | |||
</p:top> | </p:top> | ||
URI of p:top default namespace = | URI of p:top default namespace = | ||
URI of inner default namespace = urn:default | URI of inner default namespace = urn:default | ||
</p> | </nowiki></p> | ||
==Request-Cancellation Errors== | |||
<ul> | <ul> | ||
<li><var>XmlDoc</var> Namespace property not <tt>On</tt>. | <li><var>XmlDoc</var> Namespace property not <tt>On</tt>. |
Revision as of 20:34, 7 February 2011
Default URI in scope at selected node (XmlDoc and XmlNode classes)
This function gets the Uniform Resource Identifier (URI)
associated with the default namespace declaration that is in scope
at a node that is the head of an XPath result.
The DefaultURI function is new as of version 6.9 of the Sirius Mods.
Syntax
%unicode = nr:DefaultURI[( [xpath])] Throws XPathError
Syntax terms
%uri | A string variable for the returned URI. |
---|---|
nr | An XmlDoc or XmlNode, used as the context node for the XPath expression. If an XmlDoc, the Root node is the context node. |
XPath | A Unicode string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (nr). Prior to Sirius Mods version 7.6, this is an EBCDIC string. |
Example
In the following example, two elements are added along with their namespace URIs, but only the second added element, which has no prefix, has a default namespace URI:
Begin %d Object XmlDoc Auto New %n Object XmlNode %n2 Object XmlNode %n = %d:AddElement('p:top', , 'urn:top') %n2 = %n:AddElement('inner', , 'urn:default') %n:Print Print 'URI of p:top default namespace =' And %n:DefaultURI Print 'URI of inner default namespace =' And %n2:DefaultURI End
The following lines are printed:
<p:top xmlns:p="urn:top"> <inner xmlns="urn:default"/> </p:top> URI of p:top default namespace = URI of inner default namespace = urn:default
Request-Cancellation Errors
- XmlDoc Namespace property not On.
- XPath is invalid.
- Result of (XPath) is empty.
- Insufficient free space exists in CCATEMP.
See also
- For more information about using XPath expressions, see XPath.
- For more information about namespace declarations, see ?? refid=namsp..
- For more information about URIs, see ?? refid=nsuri..
- The PrefixURI method (?? refid=prefuri.) returns the URI bound to a node's prefix (or the default URI, if a node has a default namespace declaration). The URI method (?? refid=uri.) returns the URI bound to a node's name, if any.
- These methods add namespace URIs to XmlDoc nodes: