mismatch
mismatch
is a JavaScript package to return captured groups of a regular expression as objects in an array.
yarn add mismatch
Table Of Contents
API
The package is available by importing its default function:
mismatch(
re: RegExp,
string: string,
keys: string[],
addPosition?: boolean,
): void
The function will attempt to find all matches for a given regular expression in a string using .replace()
method, construct an object consisting of captured groups based on supplied keys, and return those objects as an array. It has an advantage over iterating over while(RegExp.exec(string))
pattern because it does not modify the regular expression's lastIndex
property.
/* yarn example/ */ const re = /=""/gconst string = `<script crossorigin="anonymous" src="https://static.npmjs.com/commons.js" integrity="sha512-example/rhb92Zdom+ix+AYtqZ7C1DlLKEA=="></script>`const keys = 'attribute' 'value'const res = console
If an optional capturing group was not found, its key will not be included as part of the object. Also, if there are more captured groups than keys, they will also not be included.
/* yarn example/extra.js */ const re = /?\s+crossorigin=""\s+src=""/gconst string = `<script crossorigin="anonymous" src="https://static.npmjs.com/commons.js" integrity="sha512-example/rhb92Zdom+ix+AYtqZ7C1DlLKEA=="></script>`const keys = 'type' 'crossorigin'const res = console
To additionally add the positions at which the matches was found, the last argument, addPositions
should be set to true.
/* yarn example/ */ const re = /=""/gconst string = `<script crossorigin="anonymous" src="https://static.npmjs.com/commons.js" integrity="sha512-example/rhb92Zdom+ix+AYtqZ7C1DlLKEA=="></script>`const keys = 'attribute' 'value'const res = console
Copyright
© Art Deco 2019 | Tech Nation Visa Sucks |
---|