Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thiagodp/get-xpath
📑 Extract the XPath from an HTML element
https://github.com/thiagodp/get-xpath
browser deno html javascript node typescript xpath
Last synced: 3 months ago
JSON representation
📑 Extract the XPath from an HTML element
- Host: GitHub
- URL: https://github.com/thiagodp/get-xpath
- Owner: thiagodp
- License: mit
- Created: 2020-06-04T03:19:16.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-05-15T18:11:35.000Z (over 1 year ago)
- Last Synced: 2023-05-15T19:25:21.806Z (over 1 year ago)
- Topics: browser, deno, html, javascript, node, typescript, xpath
- Language: TypeScript
- Homepage:
- Size: 270 KB
- Stars: 16
- Watchers: 3
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE.txt
Awesome Lists containing this project
README
[![npm (tag)](https://img.shields.io/npm/v/get-xpath?color=green&label=NPM&style=for-the-badge)](https://github.com/thiagodp/get-xpath/releases)
[![Build Status](https://img.shields.io/github/actions/workflow/status/thiagodp/get-xpath/test.yml?style=for-the-badge&color=green)](https://github.com/thiagodp/get-xpath/actions)
[![License](https://img.shields.io/npm/l/get-xpath.svg?style=for-the-badge&color=green)](https://github.com/thiagodp/get-xpath/blob/master/LICENSE.txt)
[![npm](https://img.shields.io/npm/dt/get-xpath?style=for-the-badge&color=green)](https://www.npmjs.com/package/get-xpath)# get-xpath
> 📑 Extract the XPath of an HTML element
- Works with browsers, [NodeJS](https://nodejs.org/) and [DenoJS](https://deno.land/) (JavaScript 5 and TypeScript)
- No external dependencies
- Unit-tested
- Semantic Versioning## Install
```bash
npm i get-xpath
```## API
```typescript
function getXPath( element: HTMLElement, options?: Partial< Options > ): string;
```Where `options` is an optional object containing:
| name | type | description |
|------------|---------|---------------------------------------|
| `ignoreId` | boolean | Do not take elements' ID into account |Example:
```html
const div = document.getElementById( 'x' );
const xpath1 = getXPath( div ); // returns '//*[@id="x"]'
const xpath2 = getXPath( div, { ignoreId: true } ); // returns '/html/body/div'
```
## Usage
**Notes**:
- On [Node](https://nodejs.org/) or [Deno](https://deno.land/), you have to provide a way to accessing or emulating the DOM.
You can use [JSDOM](https://github.com/jsdom/jsdom) (or any other library) for that.
- When using TypeScript, add the value `"dom"` to the property `"lib"`of your `tsconfig.json`. Otherwise you will probably get errors.### Browser
Global:
```html<script>
console.log(
getXPath( document.getElementById( 'foo' ) )
);```
ESM:
```htmlimport getXPath from 'https://unpkg.com/get-xpath/index.esm.js';
console.log(
getXPath( document.getElementById( 'foo' ) )
);```
### NodeJS
```javascript
///
const getXPath = require('get-xpath');
console.log(
getXPath( document.getElementById( 'foo' ) )
);
```### Deno
```typescript
///
import getXPath from 'https://unpkg.com/get-xpath/index.esm.js';
console.log(
getXPath( document.getElementById( 'foo' ) )
);
```## License
[MIT](LICENSE.txt) © [Thiago Delgado Pinto](https://github.com/thiagodp)