@DOMNoInterfaceObjectAttribute public interface IXPathEvaluator
The evaluation of XPath expressions is provided by IXPathEvaluator
.
Modifier and Type | Method and Description |
---|---|
IXPathExpression |
createExpression(String expression,
IXPathNSResolver resolver)
Creates a parsed XPath expression with resolved namespaces.
|
IXPathNSResolver |
createNSResolver(Node nodeResolver)
Adapts any DOM node to resolve namespaces so that an XPath expression can be easily evaluated
relative to the context of the node where it appeared within the document.
|
IXPathResult |
evaluate(String expression,
Node contextNode,
IXPathNSResolver resolver,
int type,
Object result)
Evaluates an XPath expression string and returns a result of the specified type if possible.
|
@DOMNameAttribute(name="createExpression") IXPathExpression createExpression(String expression, IXPathNSResolver resolver)
Creates a parsed XPath expression with resolved namespaces. This is useful when an expression will be reused in an application since it makes it possible to compile the expression string into a more efficient internal form and preresolve all namespace prefixes which occur within the expression.
expression
- The XPath expression string to be parsed.resolver
- The resolver
permits translation of all prefixes,
including the xml
namespace prefix, within the XPath expression into
appropriate namespace URIs. If this is specified as null
, any namespace
prefix within the expression will result in DOMException
being
thrown with the code NAMESPACE_ERR
.DOMException
- INVALID_EXPRESSION_ERR: Raised if the expression is not
legal according to the rules of the IXPathEvaluator
.DOMException
- NAMESPACE_ERR: Raised if the expression contains namespace
prefixes which cannot be resolved by the specified IXPathNSResolver
.@DOMNameAttribute(name="createNSResolver") IXPathNSResolver createNSResolver(Node nodeResolver)
Adapts any DOM node to resolve namespaces so that an XPath expression can be easily evaluated
relative to the context of the node where it appeared within the document. This adapter works
like the DOM Level 3 method lookupNamespaceURI
on nodes in resolving the namespaceURI
from a given prefix using the current information available in the node's hierarchy at the time
lookupNamespaceURI is called, also correctly resolving the implicit xml prefix.
nodeResolver
- The node to be used as a context for namespace resolution.IXPathNSResolver
which resolves namespaces with respect to the definitions
in scope for a specified node.@DOMNameAttribute(name="evaluate") IXPathResult evaluate(String expression, Node contextNode, IXPathNSResolver resolver, int type, Object result)
Evaluates an XPath expression string and returns a result of the specified type if possible.
expression
- The XPath expression string to be parsed and evaluated.contextNode
- The context
is context node for the evaluation of this
XPath expression. If the IXPathEvaluator
was obtained by casting the
Document
then this must be owned by the same document and must be a
Document
, Element
, Attr
, Text
,
CDATASection
, Comment
, ProcessingInstruction
,
or XPathNamespace
node. If the context node is a Text
or a
CDATASection
, then the context is interpreted as the whole logical text node
as seen by XPath, unless the node is empty in which case it may not serve as the XPath context.resolver
- The resolver
permits translation of all prefixes, including
the xml
namespace prefix, within the XPath expression into appropriate namespace URIs.
If this is specified as null
, any namespace prefix within the expression will result
in DOMException
being thrown with the code NAMESPACE_ERR
.type
- If a specific type
is specified, then the result will be returned as
the corresponding type. For XPath 1.0 results, this must be one of the values of the
XPathResultType
enum.result
- The result
specifies a specific result object which may be reused
and returned by this method. If this is specified as null
or the implementation does not
reuse the specified result, a new result object will be constructed and returned. For XPath 1.0
results, this object will be of type IXPathResult
.IXPathResult
.DOMException
- INVALID_EXPRESSION_ERR: Raised if the expression is not legal according
to the rules of the IXPathEvaluator
.DOMException
- TYPE_ERR: Raised if the result cannot be converted to return the
specified type.DOMException
- NAMESPACE_ERR: Raised if the expression contains namespace prefixes
which cannot be resolved by the specified IXPathNSResolver
.DOMException
- WRONG_DOCUMENT_ERR: The Node is from a document that is not supported
by this IXPathEvaluator
.DOMException
- NOT_SUPPORTED_ERR: The Node is not a type permitted as an XPath context
node or the request type is not permitted by this IXPathEvaluator
.