2.1.0 • Published 4 years ago
http-querystring-stringify v2.1.0
http-querystring-stringify
Simple, small and correct querystring serialization-only for the browser or server.
This package is intended for client side code or input data which structure is defined by the application. It has no DoS protection and simplicity and correctness is prioritized over performance.
If you need extreme performance you should consider https://github.com/petkaantonov/querystringparser.
This package was written because serialization seems to happen most often on the client as a single operation and similar performance-focused libraries had trade-offs and bugs while others carried huge dependencies.
const {stringify, appendToUrl} = require('http-querystring-stringify')
stringify({
first: 'John',
last: 'Wayne',
})
// -> first=John&last=Wayne
stringify({
brands: ['KitKat', 'Snickers', 'Bounty'],
})
// -> brands[]=KitKat&brands[]=Snickers&brands[]=Bounty
stringify({
sites: [{name: 'facebook', color: 'blue'}],
})
// -> sites[0][name]=facebook&sites[0][color]=blue
appendToUrl('https://google.com', {
first: 'John',
last: 'Wayne',
})
// -> https://google.com?first=John&last=Wayne
appendToUrl('https://google.com', {
key: undefined,
})
// -> https://google.comtoJSONis respected (likeJSON.stringifydoes)trueandfalseare converted toyornrespectivelynullis represented by an empty stringundefinedvalues will be skipped completely (likeJSON.stringifydoes)- arrays will be numbered only if they contain arrays or objects themselves
Compatibility with parsers
Generally there are two types of parsers: those supporting extended nesting and those that just support repeated keys.
Perfect support (extended nesting):
- querystringparser (read open issues)
- qs
const input = {
a: '',
b: 's',
c: ['1', '2', '3'],
d: '&=[]',
e: ['1', '2', ['3', '4']],
f: ['1', {a: '1'}],
}
// deepEqual(parse(stringify(input)), input)
// -> trueWill flatten:
parse(
stringify({
a: '',
b: 's',
c: ['1', '2', '3'],
d: '&=[]',
e: ['1', '2', ['3', '4']],
f: ['1', {a: '1'}],
})
)
// -> {
// a: '',
// b: 's',
// d: '&=[]',
// // expect arrays to be collapsed like this
// 'c[]': [ '1', '2', '3' ],
// // expect objects and multi-level arrays to be flattened like this
// 'e[0]': '1',
// 'e[1]': '2',
// 'e[2][]': [ '3', '4' ],
// 'f[0]': '1',
// 'f[1][a]': '1',
// }