Spaces:
Build error
Build error
| # hast-util-is-element | |
| [![Build][build-badge]][build] | |
| [![Coverage][coverage-badge]][coverage] | |
| [![Downloads][downloads-badge]][downloads] | |
| [![Size][size-badge]][size] | |
| [![Sponsors][sponsors-badge]][collective] | |
| [![Backers][backers-badge]][collective] | |
| [![Chat][chat-badge]][chat] | |
| [hast][] utility to check if a node is a (certain) element. | |
| ## Contents | |
| * [What is this?](#what-is-this) | |
| * [When should I use this?](#when-should-i-use-this) | |
| * [Install](#install) | |
| * [Use](#use) | |
| * [API](#api) | |
| * [`isElement(node[, test[, index, parent[, context]]])`](#iselementnode-test-index-parent-context) | |
| * [`convertElement(test)`](#convertelementtest) | |
| * [`AssertAnything`](#assertanything) | |
| * [`AssertPredicate`](#assertpredicate) | |
| * [`Test`](#test) | |
| * [`TestFunctionAnything`](#testfunctionanything) | |
| * [`PredicateTest`](#predicatetest) | |
| * [`TestFunctionPredicate`](#testfunctionpredicate) | |
| * [Types](#types) | |
| * [Compatibility](#compatibility) | |
| * [Security](#security) | |
| * [Related](#related) | |
| * [Contribute](#contribute) | |
| * [License](#license) | |
| ## What is this? | |
| This package is a small utility that checks that a node is a certain element. | |
| ## When should I use this? | |
| Use this small utility if you find yourself repeating code for checking what | |
| elements nodes are. | |
| A similar package, [`unist-util-is`][unist-util-is], works on any unist node. | |
| For more advanced tests, [`hast-util-select`][hast-util-select] can be used | |
| to match against CSS selectors. | |
| ## Install | |
| This package is [ESM only][esm]. | |
| In Node.js (version 14.14+ and 16.0+), install with [npm][]: | |
| ```sh | |
| npm install hast-util-is-element | |
| ``` | |
| In Deno with [`esm.sh`][esmsh]: | |
| ```js | |
| import {isElement} from 'https://esm.sh/hast-util-is-element@2' | |
| ``` | |
| In browsers with [`esm.sh`][esmsh]: | |
| ```html | |
| <script type="module"> | |
| import {isElement} from 'https://esm.sh/hast-util-is-element@2?bundle' | |
| </script> | |
| ``` | |
| ## Use | |
| ```js | |
| import {isElement} from 'hast-util-is-element' | |
| isElement({type: 'text', value: 'foo'}) // => false | |
| isElement({type: 'element', tagName: 'a'}) // => true | |
| isElement({type: 'element', tagName: 'a'}, 'a') // => true | |
| isElement({type: 'element', tagName: 'a'}, ['a', 'area']) // => true | |
| ``` | |
| ## API | |
| This package exports the identifiers [`isElement`][iselement] and | |
| [`convertElement`][convertelement]. | |
| There is no default export. | |
| ### `isElement(node[, test[, index, parent[, context]]])` | |
| Check if `node` is an `Element` and whether it passes the given test. | |
| ###### Parameters | |
| * `node` (`unknown`) | |
| — thing to check, typically [`Node`][node] | |
| * `test` ([`Test`][test] or [`PredicateTest`][predicatetest], optional) | |
| — a check for a specific element | |
| * `index` (`number`, optional) | |
| — the node’s position in its parent | |
| * `parent` ([`Node`][node], optional) | |
| — the node’s parent | |
| * `context` (`any`, optional) | |
| — context object (`this`) to call `test` with | |
| ###### Returns | |
| Whether `node` is an [`Element`][element] and passes a test (`boolean`). | |
| ###### Throws | |
| When an incorrect `test`, `index`, or `parent` is given. | |
| There is no error thrown when `node` is not a node or not an element. | |
| ### `convertElement(test)` | |
| Generate a check from a test. | |
| Useful if you’re going to test many nodes, for example when creating a | |
| utility where something else passes a compatible test. | |
| The created function is a bit faster because it expects valid input only: | |
| a `node`, `index`, and `parent`. | |
| ###### Parameters | |
| * `test` ([`Test`][test] or [`PredicateTest`][predicatetest], optional) | |
| — a check for a specific element | |
| ###### Returns | |
| An assertion ([`AssertAnything`][assertanything] or | |
| [`AssertPredicate`][assertpredicate]). | |
| ### `AssertAnything` | |
| Check that an arbitrary value is an element, unaware of TypeScript inferral | |
| (TypeScript type). | |
| ###### Parameters | |
| * `node` (`unknown`) | |
| — anything (typically a node) | |
| * `index` (`number`, optional) | |
| — the node’s position in its parent | |
| * `parent` ([`Node`][node], optional) | |
| — the node’s parent | |
| ###### Returns | |
| Whether this is an element and passes a test (`boolean`). | |
| ### `AssertPredicate` | |
| Check that an arbitrary value is a specific element, aware of TypeScript | |
| (TypeScript type). | |
| ###### Type parameters | |
| * `T` ([`Element`][element]) | |
| — element type | |
| ###### Parameters | |
| * `node` (`unknown`) | |
| — anything (typically a node) | |
| * `index` (`number`, optional) | |
| — the node’s position in its parent | |
| * `parent` ([`Node`][node], optional) | |
| — the node’s parent | |
| ###### Returns | |
| Whether this is an element and passes a test (`node is T`). | |
| ### `Test` | |
| Check for an arbitrary element, unaware of TypeScript inferral (TypeScript | |
| type). | |
| ###### Type | |
| ```ts | |
| type Test = null | undefined | string | TestFunctionAnything | Array<string | TestFunctionAnything> | |
| ``` | |
| Checks that the given thing is an element, and then: | |
| * when `string`, checks that the element has that tag name | |
| * when `function`, see [`TestFunctionAnything`][testfunctionanything] | |
| * when `Array`, checks if one of the subtests pass | |
| ### `TestFunctionAnything` | |
| Check if an element passes a test, unaware of TypeScript inferral (TypeScript | |
| type). | |
| ###### Parameters | |
| * `element` ([`Element`][element]) | |
| — an element | |
| * `index` (`number`, optional) | |
| — the element’s position in its parent | |
| * `parent` ([`Node`][node], optional) | |
| — the element’s parent | |
| ###### Returns | |
| Whether this element passes the test (`boolean`). | |
| ### `PredicateTest` | |
| Check for an element that can be inferred by TypeScript (TypeScript type). | |
| ###### Type | |
| ```ts | |
| type PredicateTest<T extends Element> = | |
| | T['tagName'] | |
| | TestFunctionPredicate<T> | |
| | Array<T['tagName'] | TestFunctionPredicate<T>> | |
| ``` | |
| See [`TestFunctionPredicate`][testfunctionpredicate]. | |
| ### `TestFunctionPredicate` | |
| Check if an element passes a certain node test (TypeScript type). | |
| ###### Type parameters | |
| * `T` ([`Element`][element]) | |
| — element type | |
| ###### Parameters | |
| * `element` ([`Element`][element]) | |
| — an element | |
| * `index` (`number`, optional) | |
| — the element’s position in its parent | |
| * `parent` ([`Node`][node], optional) | |
| — the element’s parent | |
| ###### Returns | |
| Whether this element passes the test (`element is T`). | |
| ## Types | |
| This package is fully typed with [TypeScript][]. | |
| It exports the additional types [`AssertAnything`][assertanything], | |
| [`AssertPredicate`][assertpredicate], [`Test`][test], | |
| [`TestFunctionAnything`][testfunctionanything], | |
| [`TestFunctionPredicate`][testfunctionpredicate], and | |
| [`PredicateTest`][predicatetest]. | |
| ## Compatibility | |
| Projects maintained by the unified collective are compatible with all maintained | |
| versions of Node.js. | |
| As of now, that is Node.js 14.14+ and 16.0+. | |
| Our projects sometimes work with older versions, but this is not guaranteed. | |
| ## Security | |
| `hast-util-is-element` does not change the syntax tree so there are no openings | |
| for [cross-site scripting (XSS)][xss] attacks. | |
| ## Related | |
| * [`hast-util-has-property`](https://github.com/syntax-tree/hast-util-has-property) | |
| — check if a node has a property | |
| * [`hast-util-is-body-ok-link`](https://github.com/rehypejs/rehype-minify/tree/main/packages/hast-util-is-body-ok-link) | |
| — check if a node is “Body OK” link element | |
| * [`hast-util-is-conditional-comment`](https://github.com/rehypejs/rehype-minify/tree/main/packages/hast-util-is-conditional-comment) | |
| — check if a node is a conditional comment | |
| * [`hast-util-is-css-link`](https://github.com/rehypejs/rehype-minify/tree/main/packages/hast-util-is-css-link) | |
| — check if a node is a CSS link element | |
| * [`hast-util-is-css-style`](https://github.com/rehypejs/rehype-minify/tree/main/packages/hast-util-is-css-style) | |
| — check if a node is a CSS style element | |
| * [`hast-util-embedded`](https://github.com/syntax-tree/hast-util-embedded) | |
| — check if a node is an embedded element | |
| * [`hast-util-heading`](https://github.com/syntax-tree/hast-util-heading) | |
| — check if a node is a heading element | |
| * [`hast-util-interactive`](https://github.com/syntax-tree/hast-util-interactive) | |
| — check if a node is interactive | |
| * [`hast-util-is-javascript`](https://github.com/rehypejs/rehype-minify/tree/main/packages/hast-util-is-javascript) | |
| — check if a node is a JavaScript script element | |
| * [`hast-util-labelable`](https://github.com/syntax-tree/hast-util-labelable) | |
| — check whether a node is labelable | |
| * [`hast-util-phrasing`](https://github.com/syntax-tree/hast-util-phrasing) | |
| — check if a node is phrasing content | |
| * [`hast-util-script-supporting`](https://github.com/syntax-tree/hast-util-script-supporting) | |
| — check if a node is a script-supporting element | |
| * [`hast-util-sectioning`](https://github.com/syntax-tree/hast-util-sectioning) | |
| — check if a node is a sectioning element | |
| * [`hast-util-transparent`](https://github.com/syntax-tree/hast-util-transparent) | |
| — check if a node is a transparent element | |
| * [`hast-util-whitespace`](https://github.com/syntax-tree/hast-util-whitespace) | |
| — check if a node is inter-element whitespace | |
| ## Contribute | |
| See [`contributing.md`][contributing] in [`syntax-tree/.github`][health] for | |
| ways to get started. | |
| See [`support.md`][support] for ways to get help. | |
| This project has a [code of conduct][coc]. | |
| By interacting with this repository, organization, or community you agree to | |
| abide by its terms. | |
| ## License | |
| [MIT][license] © [Titus Wormer][author] | |
| <!-- Definition --> | |
| [build-badge]: https://github.com/syntax-tree/hast-util-is-element/workflows/main/badge.svg | |
| [build]: https://github.com/syntax-tree/hast-util-is-element/actions | |
| [coverage-badge]: https://img.shields.io/codecov/c/github/syntax-tree/hast-util-is-element.svg | |
| [coverage]: https://codecov.io/github/syntax-tree/hast-util-is-element | |
| [downloads-badge]: https://img.shields.io/npm/dm/hast-util-is-element.svg | |
| [downloads]: https://www.npmjs.com/package/hast-util-is-element | |
| [size-badge]: https://img.shields.io/bundlephobia/minzip/hast-util-is-element.svg | |
| [size]: https://bundlephobia.com/result?p=hast-util-is-element | |
| [sponsors-badge]: https://opencollective.com/unified/sponsors/badge.svg | |
| [backers-badge]: https://opencollective.com/unified/backers/badge.svg | |
| [collective]: https://opencollective.com/unified | |
| [chat-badge]: https://img.shields.io/badge/chat-discussions-success.svg | |
| [chat]: https://github.com/syntax-tree/unist/discussions | |
| [npm]: https://docs.npmjs.com/cli/install | |
| [esm]: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c | |
| [esmsh]: https://esm.sh | |
| [typescript]: https://www.typescriptlang.org | |
| [license]: license | |
| [author]: https://wooorm.com | |
| [health]: https://github.com/syntax-tree/.github | |
| [contributing]: https://github.com/syntax-tree/.github/blob/main/contributing.md | |
| [support]: https://github.com/syntax-tree/.github/blob/main/support.md | |
| [coc]: https://github.com/syntax-tree/.github/blob/main/code-of-conduct.md | |
| [hast]: https://github.com/syntax-tree/hast | |
| [node]: https://github.com/syntax-tree/unist#node | |
| [element]: https://github.com/syntax-tree/hast#element | |
| [xss]: https://en.wikipedia.org/wiki/Cross-site_scripting | |
| [unist-util-is]: https://github.com/syntax-tree/unist-util-is | |
| [hast-util-select]: https://github.com/syntax-tree/hast-util-select | |
| [iselement]: #iselementnode-test-index-parent-context | |
| [convertelement]: #convertelementtest | |
| [assertanything]: #assertanything | |
| [assertpredicate]: #assertpredicate | |
| [test]: #test | |
| [testfunctionanything]: #testfunctionanything | |
| [predicatetest]: #predicatetest | |
| [testfunctionpredicate]: #testfunctionpredicate | |