Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/niksy/string-match-all

`String.prototype.matchAll` ponyfill.
https://github.com/niksy/string-match-all

Last synced: about 2 months ago
JSON representation

`String.prototype.matchAll` ponyfill.

Awesome Lists containing this project

README

        

# string-match-all

[![Build Status][ci-img]][ci]
[![Browser testing by BrowserStack][browserstack-img]][browserstack]

[`String.prototype.matchAll`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/matchAll)
[ponyfill](https://ponyfill.com).

> The `String.prototype.matchAll` returns an iterator of all results matching a
> string against a regular expression, including capturing groups.

## Install

```sh
npm install string-match-all --save
```

## Usage

```js
import matchAll from 'string-match-all';

const matches = [...matchAll('test1test2', /t(e)(st(\d?))/g)];

// ["test1", "e", "st1", "1", index: 0, input: "test1test2"]
// ["test2", "e", "st2", "2", index: 5, input: "test1test2"]
```

You can **use named export `preferNative` if you wish to use native
implementation if it’s available**. In all other cases, ponyfill will be used.
Beware of
[caveats](https://github.com/sindresorhus/ponyfill#user-content-ponyfill:~:text=Ponyfills%20should%20never%20use%20the%20native,between%20environments%2C%20which%20can%20cause%20bugs.)!

## API

### matchAll(string, matcher)

Returns: `Iterator`

#### string

Type: `string`

String to match.

#### matcher

Type: `string|RegExp`

Value to match original string.

If a non-`RegExp` object is passed, it is implicitly converted to a `RegExp` by
using `new RegExp(regexp, 'g')`.

The `RegExp` object must have the `global` flag, otherwise a `TypeError` will be
thrown.

## Browser support

Tested in Chrome 91, Firefox 90, Internet Explorer 11 and should work in all
modern browsers
([support based on Browserslist configuration](https://browserslist.dev/?q=bGFzdCAyIHZlcnNpb25zLCBub3QgaWUgMTAsIGllID49IDEx)).

## Test

Test suite is taken and modified from
[es-shims](https://github.com/es-shims/String.prototype.matchAll/blob/main/test/tests.js)
test suite.

For automated tests, run `npm run test:automated` (append `:watch` for watcher
support).

## License

MIT © [Ivan Nikolić](http://ivannikolic.com)

[ci]: https://travis-ci.com/niksy/string-match-all
[ci-img]: https://travis-ci.com/niksy/string-match-all.svg?branch=master
[browserstack]: https://www.browserstack.com/
[browserstack-img]: https://img.shields.io/badge/browser%20testing-BrowserStack-informational?logo=