Skip to content

Simple queryXPath() and queryXPathAll() functions for JavaScript

License

Notifications You must be signed in to change notification settings

tomhodgins/queryxpath

Repository files navigation

queryxpath

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.

Usage

This plugin is provided in the following formats and files:

  • queryxpath.cjs.js a Node-formatted CommonJS module
  • queryxpath.es.js a vanilla ES module
  • queryxpath.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().

Document prototype

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.

Example

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.

About

Simple queryXPath() and queryXPathAll() functions for JavaScript

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published