This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
This method compiles an XPathExpression which can then be used for (repeated) evaluations of the XPath expression.
createExpression(expression) createExpression(expression, resolver)
expressionA string representing the XPath expression to be created.
resolver OptionalA Node, null, or any object implementing the lookupNamespaceURI method. Permits translation of all prefixes, including the xml namespace prefix, within the XPath expression into appropriate namespace URIs.
A XPathExpression representing the compiled form of the XPath expression.
If the expression is not legal according to the rules of the XPathEvaluator, a DOMException of type INVALID_EXPRESSION_ERR is raised.
If the expression contains namespace prefixes which cannot be resolved by the specified XPathNSResolver, a DOMException of type NAMESPACE_ERROR is raised.
The following example shows the use of the evaluate() method.
<div>XPath example</div> <div>Number of <div>s: <output></output></div>
const xpath = "//div";
const evaluator = new XPathEvaluator();
const expression = evaluator.createExpression(xpath);
const result = expression.evaluate(
document,
XPathResult.ORDERED_NODE_SNAPSHOT_TYPE,
);
document.querySelector("output").textContent = result.snapshotLength;
| Specification |
|---|
| DOM> # dom-xpathevaluatorbase-createexpression> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
createExpression |
1 | 12 | 1 | ≤12.1 | 3 | 18 | 4 | ≤12.1 | 1 | 1.0 | 4.4 | 1 |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/XPathEvaluator/createExpression