Simple queryXPath()
and queryXPathAll()
functions for JavaScript
These functions add the ability to query the document for elements that match XPath selectors, and returns them in an array. They act as a simple layer of abstraction covering over the details of document.evaluate()
, which is the platform native way to query XPath from JavaScript, and provide a simpler UI for developers working with XPaths in the browser.
This plugin is provided in the following formats and files:
queryxpath.cjs.js
a Node-formatted CommonJS modulequeryxpath.es.js
a vanilla ES modulequeryxpath.browser.js
a script containing named functions
The simplest way to use these functions are to load the JavaScript file on a page where you want to use it:
<script src=https://tomhodgins.github.io/queryxpath/queryxpath.browser.js></script>
Then you should be able to make use of queryXPath()
and queryXPathAll()
right away. The queryXPath()
function returns only one result, the first result from queryXPathAll()
.
If you want to mimic document.querySelector()
and document.querySelectorAll()
you can also mutilate the Document
prototype to include these functions on document
with the following lines:
Document.prototype.queryXPath = queryXPath
Document.prototype.queryXPathAll = queryXPathAll
However, this could conflict with any potential future use of queryXPath
or queryXPathAll
natively that could show up at any time in the future.
Here's a simple usage example of both helper functions:
<ul>
<li>item
<li class=target>item
<li>item
</ul>
<script src=https://tomhodgins.github.io/queryxpath/queryxpath.browser.js></script>
<script>
// Selecting the <ul> as the parent of <li class=target>
queryXPath('//li[@class="target"]/parent::*').style.border = '4px dashed orange'
// Selecting all <li> elements
queryXPathAll('//li').forEach(tag => tag.style.border = '4px dashed blue')
</script>
For a more detailed example of what you can do with XPath, check out the XPath Selector Demo test page.