schangxiang@126.com
2025-09-19 df5675b4e548eff2dbab6c780b173c346551f508
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# `XPathEvaluator`
 
The `xpath.parse()` method returns an `XPathEvaluator`, which contains the following methods.
 
Each of these methods takes an optional `options` object, which can contain any of the following properties:
 
`namespaces` - a namespace resolver. See the [documentation page](namespace%20resolvers.md) for details.
 
`variables` - a variable resolver. See the [documentation page](variable%20resolvers.md) for details.
 
`functions` - a function resolver. See the [documentation page](function%20resolvers.md) for details.
 
`node` - the context node for evaluating the expression
 
Example usage: 
 
```js
var evaluator = xpath.parse('/characters/character[@greeting = $greeting]');
var character = evaluator.select1({
    node: myCharacterDoc,
    variables: {
        greeting: "Hello, I'm Harry, Harry Potter."
    }
});
```
 
## `XPathEvaluator` methods
 
`evaluate([options])`
 
Evaluates the XPath expression and returns the result. The resulting type is determined based on the type of the expression, using the same criteria as [`xpath.select`](xpath%20methods.md).
 
`evaluateNumber([options])`
 
Evaluates the XPath expression and returns the result as a number.
 
`evaluateString([options])`
 
Evaluates the XPath expression and returns the result as a string.
 
`evaluateBoolean([options])`
 
Evaluates the XPath expression and returns the result as a boolean value.
 
`evaluateNodeSet([options])`
 
Evaluates the XPath expression and returns the result as an XNodeSet. See the [documentation page](#) for details on this interface.
 
This is only valid for expressions that evaluate to a node set.
 
`select([options])`
 
Evaluates the XPath expression and returns an array of the resulting nodes, in document order.
 
This is only valid for expressions that evaluate to a node set.
 
`select1([options])`
 
Evaluates the XPath expression and the first node in the resulting node set, in document order. Returns `undefined` 
 
This is only valid for expressions that evaluate to a node set.