Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/immobiliare/radix3
🌳 Lightweight and fast router for JavaScript based on Radix Tree. This fork adds functional matching!
https://github.com/immobiliare/radix3
javascript nodejs radix-tree router
Last synced: 2 months ago
JSON representation
🌳 Lightweight and fast router for JavaScript based on Radix Tree. This fork adds functional matching!
- Host: GitHub
- URL: https://github.com/immobiliare/radix3
- Owner: immobiliare
- License: mit
- Created: 2022-10-20T14:42:19.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-02-19T10:28:58.000Z (11 months ago)
- Last Synced: 2024-11-01T14:17:02.123Z (3 months ago)
- Topics: javascript, nodejs, radix-tree, router
- Language: TypeScript
- Homepage:
- Size: 1.21 MB
- Stars: 13
- Watchers: 2
- Forks: 0
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# 🌳 radix3
![release workflow](https://img.shields.io/github/workflow/status/immobiliare/radix3/Release)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier?style=flat-square)
[![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg?style=flat-square)](https://github.com/semantic-release/semantic-release)
![npm (scoped)](https://img.shields.io/npm/v/@immobiliarelabs/radix3?style=flat-square)
![license](https://img.shields.io/github/license/immobiliare/radix3)Lightweight and fast router for JavaScript based on [Radix Tree](https://en.wikipedia.org/wiki/Radix_tree).
This fork of [`unjs/radix3`](https://github.com/unjs/radix3) adds functional matching `::function` to the base library.- [🌳 radix3](#%F0%9F%8C%B3-radix3)
* [Usage](#usage)
* [Methods](#methods)
+ [`router.insert(path, data)`](#routerinsertpath-data)
+ [`router.lookup(path)`](#routerlookuppath)
+ [`router.remove(path)`](#routerremovepath)
* [Options](#options)
+ [Route Matcher](#route-matcher)
* [Performance](#performance)
* [Powered Apps](#powered-apps)
* [Support & Contribute](#support--contribute)
* [License](#license)## Usage
**Install package:**
```sh
# npm
npm i @immobiliarelabs/radix3# yarn
yarn add @immobiliarelabs/radix3# pnpm
pnpm i @immobiliarelabs/radix3
```**Import:**
```js
// ESM
import { createRouter } from '@immobiliarelabs/radix3'// CJS
const { createRouter } = require('@immobiliarelabs/radix3')
```**Create a router instance and insert routes:**
```js
const router = createRouter(/* options */)router.insert('/path', { payload: 'this path' })
router.insert('/path/:name', { payload: 'named route' })
router.insert('/path/foo/**', { payload: 'wildcard route' })
router.insert('/path/foo/**:name', { payload: 'named wildcard route' })
```***Match route to access matched data:**
```js
// { payload: 'this path' }
router.lookup('/path')// { payload: 'named route', params: { name: 'fooval' } }
router.lookup('/path/fooval')// { payload: 'wildcard route' }
router.lookup('/path/foo/bar/baz')// null (no route matched for/)
router.lookup('/')
```## Methods
### `router.insert(path, data)`
`path` can be static or using `:placeholder`s and `**` for wildcard paths or else using `::functionName` for functional match.
The `data` object will be returned on matching params. It should be an object like `{ handler }` and not containing reserved keyword `params`.
### `router.lookup(path)`
Returns matched data for `path` with optional `params` key if mached route using placeholders.
### `router.remove(path)`
Remove route matching `path`.
## Options
You can initialize router instance with options:
```ts
const router = createRouter({
strictTrailingSlash: true,
routes: {
'/foo': {},
'/::len': {} // Matches all routes //
},
funcs: {
len: (str) => str.length === 2,
}
})```
- `routes`: An object specifying initial routes to add
- `strictTrailingSlash`: By default router ignored trailing slash for matching and adding routes. When set to `true`, matching with trailing slash is different.
- `funcs`: An object containing the functions used in the routes
- `parseParameters`: By default this variable is set to `true`. When set to `false`, the `params` attribute will not be present in the lookup function output object. Putting this parameter to `false` increases the lookup performance by 3x for dynamic routes.### Route Matcher
**Experimental feature:** Behavior might change in a semver-minor release.
Creates a multi matcher from router tree that can match **all routes** matching path:
```ts
import { createRouter, toRouteMatcher } from 'radix3'const router = createRouter({
routes: {
'/foo': { m: 'foo' }, // Matches /foo only
'/foo/**': { m: 'foo/**' }, // Matches /foo/
'/foo/bar': { m: 'foo/bar' }, // Matches /foo/bar only
'/foo/bar/baz': { m: 'foo/bar/baz' }, // Matches /foo/bar/baz only
'/foo/*/baz': { m: 'foo/*/baz' } // Matches /foo//baz
},
funcs: {
len: (str) => str.length === 2,
}
})const matcher = toRouteMatcher(router)
const matches = matcher.matchAll('/foo/bar/baz')
// [
// {
// "m": "foo/**",
// },
// {
// "m": "foo/*/baz",
// },
// {
// "m": "foo/bar/baz",
// },
// ]
```## Performance
See [benchmark](./benchmark).
## Powered Apps
`@immobiliarelabs/radix3` is a fork of [radix3](https://github.com/unjs/radix3) and `@immobiliarelabs/radix3` was created by the amazing Node.js team at ImmobiliareLabs, the Tech dept of [Immobiliare.it](https://www.immobiliare.it), the #1 real estate company in Italy.
We are currently using radix3 in our products as well as our internal toolings.
**If you are using radix3 in production [drop us a message](mailto:[email protected])**.
## Support & Contribute
Made with ❤️ by [ImmobiliareLabs](https://github.com/immobiliare) & [Contributors](./CONTRIBUTING.md#contributors)
We'd love for you to contribute to radix3!
If you have any questions on how to use radix3, bugs and enhancement please feel free to reach out by opening a [GitHub Issue](https://github.com/immobiliare/radix3/issues).## License
Based on original work of [`charlieduong94/radix-router`](https://github.com/charlieduong94/radix-router) by [Charlie Duong](https://github.com/charlieduong94) (MIT) and [`unjs/radix3`](https://github.com/unjs/radix3) [LICENSE](https://github.com/unjs/radix3/blob/main/LICENSE)
[MIT](./LICENSE) - Made with ❤️
[npm-version-src]: https://img.shields.io/npm/v/radix3?style=flat-square
[npm-version-href]: https://npmjs.com/package/radix3[npm-downloads-src]: https://img.shields.io/npm/dm/radix3?style=flat-square
[npm-downloads-href]: https://npmjs.com/package/radix3[github-actions-src]: https://img.shields.io/github/workflow/status/unjs/radix3/ci/main?style=flat-square
[github-actions-href]: https://github.com/unjs/radix3/actions?query=workflow%3Aci[codecov-src]: https://img.shields.io/codecov/c/gh/unjs/radix3/main?style=flat-square
[codecov-href]: https://codecov.io/gh/unjs/radix3[bundle-src]: https://img.shields.io/bundlephobia/minzip/radix3?style=flat-square
[bundle-href]: https://bundlephobia.com/result?p=radix3