You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
5.7 KiB
92 lines
5.7 KiB
3 years ago
|
# fast-querystring
|
||
|
|
||
|

|
||
|
[](https://codecov.io/gh/anonrig/fast-querystring)
|
||
|
[](https://www.npmjs.com/package/fast-querystring)
|
||
|
|
||
|
Fast query-string parser and stringifier to replace the legacy `node:querystring` module.
|
||
|
|
||
|
### Installation
|
||
|
|
||
|
```
|
||
|
npm i fast-querystring
|
||
|
```
|
||
|
|
||
|
### Features
|
||
|
|
||
|
- Supports both `parse` and `stringify` methods from `node:querystring` module
|
||
|
- Parsed object does not have prototype methods
|
||
|
- Uses `&` separator as default
|
||
|
- Supports only input of type `string`
|
||
|
- Supports repeating keys in query string
|
||
|
- `foo=bar&foo=baz` parses into `{foo: ['bar', 'baz']}`
|
||
|
- Supports pairs with missing values
|
||
|
- `foo=bar&hola` parses into `{foo: 'bar', hola: ''}`
|
||
|
- Stringify does not support nested values (just like `node:querystring`)
|
||
|
|
||
|
### Usage
|
||
|
|
||
|
```javascript
|
||
|
const qs = require('fast-querystring')
|
||
|
|
||
|
// Parsing a querystring
|
||
|
console.log(qs.parse('hello=world&foo=bar&values=v1&values=v2'))
|
||
|
// {
|
||
|
// hello: 'world',
|
||
|
// foo: 'bar',
|
||
|
// values: ['v1', 'v2']
|
||
|
// }
|
||
|
|
||
|
// Stringifying an object
|
||
|
console.log(qs.stringify({ foo: ['bar', 'baz'] }))
|
||
|
// 'foo=bar&foo=baz'
|
||
|
```
|
||
|
|
||
|
### Benchmark
|
||
|
|
||
|
- Parsing a query-string
|
||
|
|
||
|
```
|
||
|
> node benchmark/parse.mjs
|
||
|
|
||
|
╔═════════════════════════════════════════╤═════════╤═══════════════════╤═══════════╗
|
||
|
║ Slower tests │ Samples │ Result │ Tolerance ║
|
||
|
╟─────────────────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ qs │ 10000 │ 310825.09 op/sec │ ± 1.29 % ║
|
||
|
║ query-string │ 1000 │ 340059.83 op/sec │ ± 0.82 % ║
|
||
|
║ querystringify │ 10000 │ 435456.34 op/sec │ ± 1.06 % ║
|
||
|
║ @aws-sdk/querystring-parser │ 1000 │ 451618.35 op/sec │ ± 0.85 % ║
|
||
|
║ URLSearchParams-with-Object.fromEntries │ 10000 │ 876030.86 op/sec │ ± 1.78 % ║
|
||
|
║ URLSearchParams-with-construct │ 10000 │ 1239366.24 op/sec │ ± 2.59 % ║
|
||
|
║ node:querystring │ 10000 │ 1442731.43 op/sec │ ± 2.95 % ║
|
||
|
║ querystringparser │ 3000 │ 1863385.29 op/sec │ ± 0.99 % ║
|
||
|
╟─────────────────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ Fastest test │ Samples │ Result │ Tolerance ║
|
||
|
╟─────────────────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ fast-querystring │ 10000 │ 2086260.18 op/sec │ ± 3.18 % ║
|
||
|
╚═════════════════════════════════════════╧═════════╧═══════════════════╧═══════════╝
|
||
|
```
|
||
|
|
||
|
- Stringify a query-string
|
||
|
|
||
|
```
|
||
|
> node benchmark/stringify.mjs
|
||
|
|
||
|
╔══════════════════════════════╤═════════╤═══════════════════╤═══════════╗
|
||
|
║ Slower tests │ Samples │ Result │ Tolerance ║
|
||
|
╟──────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ query-string │ 10000 │ 294354.42 op/sec │ ± 1.25 % ║
|
||
|
║ qs │ 10000 │ 349992.31 op/sec │ ± 1.45 % ║
|
||
|
║ @aws-sdk/querystring-builder │ 10000 │ 380426.03 op/sec │ ± 1.69 % ║
|
||
|
║ http-querystring-stringify │ 10000 │ 489248.93 op/sec │ ± 1.54 % ║
|
||
|
║ URLSearchParams │ 10000 │ 579241.21 op/sec │ ± 1.92 % ║
|
||
|
║ querystringparser │ 1500 │ 667303.72 op/sec │ ± 0.77 % ║
|
||
|
║ querystringify │ 10000 │ 780283.61 op/sec │ ± 2.43 % ║
|
||
|
║ node:querystring │ 10000 │ 1779241.34 op/sec │ ± 6.49 % ║
|
||
|
╟──────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ Fastest test │ Samples │ Result │ Tolerance ║
|
||
|
╟──────────────────────────────┼─────────┼───────────────────┼───────────╢
|
||
|
║ fast-querystring │ 10000 │ 2125769.45 op/sec │ ± 3.93 % ║
|
||
|
╚══════════════════════════════╧═════════╧═══════════════════╧═══════════╝
|
||
|
```
|