# Path-to-RegExp > Turn an Express-style path string such as `/user/:name` into a regular expression. [![NPM version][npm-image]][npm-url] [![Build status][travis-image]][travis-url] [![Test coverage][coveralls-image]][coveralls-url] [![Dependency Status][david-image]][david-url] [![License][license-image]][license-url] [![Downloads][downloads-image]][downloads-url] ## Installation ``` npm install path-to-regexp --save ``` ## Usage ```javascript var pathToRegexp = require('path-to-regexp') // pathToRegexp(path, keys, options) // pathToRegexp.parse(path) // pathToRegexp.compile(path) ``` - **path** An Express-style string, an array of strings, or a regular expression. - **keys** An array to be populated with the keys found in the path. - **options** - **sensitive** When `true` the route will be case sensitive. (default: `false`) - **strict** When `false` the trailing slash is optional. (default: `false`) - **end** When `false` the path will match at the beginning. (default: `true`) - **delimiter** Set the default delimiter for repeat parameters. (default: `'/'`) ```javascript var keys = [] var re = pathToRegexp('/foo/:bar', keys) // re = /^\/foo\/([^\/]+?)\/?$/i // keys = [{ name: 'bar', prefix: '/', delimiter: '/', optional: false, repeat: false, pattern: '[^\\/]+?' }] ``` **Please note:** The `RegExp` returned by `path-to-regexp` is intended for use with pathnames or hostnames. It can not handle the query strings or fragments of a URL. ### Parameters The path string can be used to define parameters and populate the keys. #### Named Parameters Named parameters are defined by prefixing a colon to the parameter name (`:foo`). By default, the parameter will match until the following path segment. ```js var re = pathToRegexp('/:foo/:bar', keys) // keys = [{ name: 'foo', prefix: '/', ... }, { name: 'bar', prefix: '/', ... }] re.exec('/test/route') //=> ['/test/route', 'test', 'route'] ``` **Please note:** Named parameters must be made up of "word characters" (`[A-Za-z0-9_]`). ```js var re = pathToRegexp('/(apple-)?icon-:res(\\d+).png', keys) // keys = [{ name: 0, prefix: '/', ... }, { name: 'res', prefix: '', ... }] re.exec('/icon-76.png') //=> ['/icon-76.png', undefined, '76'] ``` #### Modified Parameters ##### Optional Parameters can be suffixed with a question mark (`?`) to make the parameter optional. This will also make the prefix optional. ```js var re = pathToRegexp('/:foo/:bar?', keys) // keys = [{ name: 'foo', ... }, { name: 'bar', delimiter: '/', optional: true, repeat: false }] re.exec('/test') //=> ['/test', 'test', undefined] re.exec('/test/route') //=> ['/test', 'test', 'route'] ``` ##### Zero or more Parameters can be suffixed with an asterisk (`*`) to denote a zero or more parameter matches. The prefix is taken into account for each match. ```js var re = pathToRegexp('/:foo*', keys) // keys = [{ name: 'foo', delimiter: '/', optional: true, repeat: true }] re.exec('/') //=> ['/', undefined] re.exec('/bar/baz') //=> ['/bar/baz', 'bar/baz'] ``` ##### One or more Parameters can be suffixed with a plus sign (`+`) to denote a one or more parameter matches. The prefix is taken into account for each match. ```js var re = pathToRegexp('/:foo+', keys) // keys = [{ name: 'foo', delimiter: '/', optional: false, repeat: true }] re.exec('/') //=> null re.exec('/bar/baz') //=> ['/bar/baz', 'bar/baz'] ``` #### Custom Match Parameters All parameters can be provided a custom regexp, which overrides the default (`[^\/]+`). ```js var re = pathToRegexp('/:foo(\\d+)', keys) // keys = [{ name: 'foo', ... }] re.exec('/123') //=> ['/123', '123'] re.exec('/abc') //=> null ``` **Please note:** Backslashes need to be escaped with another backslash in strings. #### Unnamed Parameters It is possible to write an unnamed parameter that only consists of a matching group. It works the same as a named parameter, except it will be numerically indexed. ```js var re = pathToRegexp('/:foo/(.*)', keys) // keys = [{ name: 'foo', ... }, { name: 0, ... }] re.exec('/test/route') //=> ['/test/route', 'test', 'route'] ``` #### Asterisk An asterisk can be used for matching everything. It is equivalent to an unnamed matching group of `(.*)`. ```js var re = pathToRegexp('/foo/*', keys) // keys = [{ name: '0', ... }] re.exec('/foo/bar/baz') //=> ['/foo/bar/baz', 'bar/baz'] ``` ### Parse The parse function is exposed via `pathToRegexp.parse`. This will return an array of strings and keys. ```js var tokens = pathToRegexp.parse('/route/:foo/(.*)') console.log(tokens[0]) //=> "/route" console.log(tokens[1]) //=> { name: 'foo', prefix: '/', delimiter: '/', optional: false, repeat: false, pattern: '[^\\/]+?' } console.log(tokens[2]) //=> { name: 0, prefix: '/', delimiter: '/', optional: false, repeat: false, pattern: '.*' } ``` **Note:** This method only works with Express-style strings. ### Compile ("Reverse" Path-To-RegExp) Path-To-RegExp exposes a compile function for transforming an Express-style path into a valid path. ```js var toPath = pathToRegexp.compile('/user/:id') toPath({ id: 123 }) //=> "/user/123" toPath({ id: 'café' }) //=> "/user/caf%C3%A9" toPath({ id: '/' }) //=> "/user/%2F" toPath({ id: ':' }) //=> "/user/%3A" toPath({ id: ':' }, { pretty: true }) //=> "/user/:" var toPathRepeated = pathToRegexp.compile('/:segment+') toPathRepeated({ segment: 'foo' }) //=> "/foo" toPathRepeated({ segment: ['a', 'b', 'c'] }) //=> "/a/b/c" var toPathRegexp = pathToRegexp.compile('/user/:id(\\d+)') toPathRegexp({ id: 123 }) //=> "/user/123" toPathRegexp({ id: '123' }) //=> "/user/123" toPathRegexp({ id: 'abc' }) //=> Throws `TypeError`. ``` **Note:** The generated function will throw on invalid input. It will do all necessary checks to ensure the generated path is valid. This method only works with strings. ### Working with Tokens Path-To-RegExp exposes the two functions used internally that accept an array of tokens. * `pathToRegexp.tokensToRegExp(tokens, options)` Transform an array of tokens into a matching regular expression. * `pathToRegexp.tokensToFunction(tokens)` Transform an array of tokens into a path generator function. #### Token Information * `name` The name of the token (`string` for named or `number` for index) * `prefix` The prefix character for the segment (`/` or `.`) * `delimiter` The delimiter for the segment (same as prefix or `/`) * `optional` Indicates the token is optional (`boolean`) * `repeat` Indicates the token is repeated (`boolean`) * `partial` Indicates this token is a partial path segment (`boolean`) * `pattern` The RegExp used to match this token (`string`) * `asterisk` Indicates the token is an `*` match (`boolean`) ## Compatibility with Express <= 4.x Path-To-RegExp breaks compatibility with Express <= `4.x`: * No longer a direct conversion to a RegExp with sugar on top - it's a path matcher with named and unnamed matching groups * It's unlikely you previously abused this feature, it's rare and you could always use a RegExp instead * All matching RegExp special characters can be used in a matching group. E.g. `/:user(.*)` * Other RegExp features are not support - no nested matching groups, non-capturing groups or look aheads * Parameters have suffixes that augment meaning - `*`, `+` and `?`. E.g. `/:user*` ## TypeScript Includes a [`.d.ts`](index.d.ts) file for TypeScript users. ## Live Demo You can see a live demo of this library in use at [express-route-tester](http://forbeslindesay.github.com/express-route-tester/). ## License MIT [npm-image]: https://img.shields.io/npm/v/path-to-regexp.svg?style=flat [npm-url]: https://npmjs.org/package/path-to-regexp [travis-image]: https://img.shields.io/travis/pillarjs/path-to-regexp.svg?style=flat [travis-url]: https://travis-ci.org/pillarjs/path-to-regexp [coveralls-image]: https://img.shields.io/coveralls/pillarjs/path-to-regexp.svg?style=flat [coveralls-url]: https://coveralls.io/r/pillarjs/path-to-regexp?branch=master [david-image]: http://img.shields.io/david/pillarjs/path-to-regexp.svg?style=flat [david-url]: https://david-dm.org/pillarjs/path-to-regexp [license-image]: http://img.shields.io/npm/l/path-to-regexp.svg?style=flat [license-url]: LICENSE.md [downloads-image]: http://img.shields.io/npm/dm/path-to-regexp.svg?style=flat [downloads-url]: https://npmjs.org/package/path-to-regexp