Package Exports
- functional-regex
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (functional-regex) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Functional Regex
Functional Regex simplifies the way you work with global regular expressions in JavaScript.
Functional Regex aims to simplify the process of iterating over a global regular expression. It is
often easier to treat the results of a globally matched regular expression as an array. It is then
possible to use map
, reduce
, forEach
, some
, filter
, etc on the results.
Example
When looking for something like /foo(test)/g it's necessary to do:
var regex = /foo(test)/g,
result;
while ((result = regex.exec(test)) !== null) {
// do something with result
};
Wouldn't it be nice if we could do something more like:
var fregex = require('functional-regex');
fregex(/[\d+]/g, '1. There is 2 numbers in this string'); // == ['1', '2']
Because it's simply an array, we can use forEach
and map
on it as well as other array methods.
var fregex = require('functional-regex');
fregex(/[\d+]/g, '1. There is 2 numbers in this string')
.map(function(x) {
return parseInt(x, 10);
}); // == [1, 2]
Installation
npm install --save functional-regex
Usage
There are three ways to use Functional Regex.
- Standalone (default, because extending native prototypes is evil)
- Legacy (also does not modify prototypes)
- Augmenting the RegExp prototype
1. Standalone
var fregex = require('functional-regex');
fregex(regex, text); // => array
2. Standalone (legacy)
var fregex = require('functional-regex');
fregex.forEach(regex, text, iteratorFn);
fregex.map(regex, text, iteratorFn);
3. RegExp prototype
require('functional-regex').addToRegExp();
var regex = /foo/g;
regex.forEach(text, iteratorFn);
regex.map(text, iteratorFn);
Contributing
Open an issue, or submit a pull-request.