Маршрутизатор для Node.js на основе префиксного дерева

e22m4u 58301b7224 chore: updates dependencies 1 год назад
.husky 0236965871 chore: adds CommonJS support 1 год назад
dist 0236965871 chore: adds CommonJS support 1 год назад
src a7b2281298 chore: upgrades path-to-regexp to 8.1.0 1 год назад
.c8rc 8a94327bc6 chore: initial commit 1 год назад
.commitlintrc 8a94327bc6 chore: initial commit 1 год назад
.editorconfig 8a94327bc6 chore: initial commit 1 год назад
.gitignore 8a94327bc6 chore: initial commit 1 год назад
.mocharc.cjs 8a94327bc6 chore: initial commit 1 год назад
.prettierrc 8a94327bc6 chore: initial commit 1 год назад
LICENSE 8a94327bc6 chore: initial commit 1 год назад
README-ru.md b953360b7f chore: updates readme 1 год назад
README.md b953360b7f chore: updates readme 1 год назад
build-cjs.js 0236965871 chore: adds CommonJS support 1 год назад
eslint.config.js 8a94327bc6 chore: initial commit 1 год назад
package.json 58301b7224 chore: updates dependencies 1 год назад
tsconfig.json 8a94327bc6 chore: initial commit 1 год назад

README-ru.md

@e22m4u/js-path-trie

English | Русский

Маршрутизатор для Node.js на основе префиксного дерева (trie).

  • Использует path-to-regexp синтаксис.
  • Поддерживает параметры маршрута.

Установка

Требуется Node.js 16 и выше.

npm install @e22m4u/js-path-trie

Модуль поддерживает ESM и CommonJS стандарты.

ESM

import {PathTrie} from '@e22m4u/js-path-trie';

CommonJS

const {PathTrie} = require('@e22m4u/js-path-trie');

Обзор

Класс PathTrie имеет следующие методы:

  • add(pathTemplate: string, value: unknown) добавить значение к новому маршруту
  • match(path: string) поиск значения по заданному маршруту

Пример:

import {PathTrie} from '@e22m4u/js-path-trie';

const trie = new PathTrie();

// добавление маршрутов выполняется
// методом "add", который принимает
// шаблон маршрута и его значение
trie.add('/foo/bar', yourValue1);
trie.add('/foo/:p1/bar/:p2', yourValue2);

// для поиска значения используется
// метод "match", который возвращает
// значение маршрута и его параметры
trie.match('/foo/bar');
// {
//   value: yourValue1,
//   params: {}
// }

// если маршрут имеет параметры,
// то их значения вернуться
// в результате поиска
trie.match('/foo/10/bar/20');
// {
//   value: yourValue2,
//   params: {p1: 10, p2: 20}
// }

// если маршрут не найден,
// то возвращается "undefined"
trie.match('/foo/bar/baz');
// undefined

Отладка

Установка переменной DEBUG включает вывод логов.

DEBUG=jsPathTrie* npm run test

Тестирование

npm run test

Лицензия

MIT