Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lukeed/qss
A tiny (294b) browser utility for encoding & decoding a querystring.
https://github.com/lukeed/qss
Last synced: 2 months ago
JSON representation
A tiny (294b) browser utility for encoding & decoding a querystring.
- Host: GitHub
- URL: https://github.com/lukeed/qss
- Owner: lukeed
- License: mit
- Created: 2017-10-23T06:26:30.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-03-10T01:59:28.000Z (almost 2 years ago)
- Last Synced: 2024-07-23T23:21:33.747Z (6 months ago)
- Language: JavaScript
- Homepage:
- Size: 30.3 KB
- Stars: 425
- Watchers: 8
- Forks: 17
- Open Issues: 5
-
Metadata Files:
- Readme: readme.md
- License: license.md
Awesome Lists containing this project
- awesome - qss - A tiny (294b) browser utility for encoding & decoding a querystring. (JavaScript)
- awesome-tiny-js - qss - Parse querystrings in <img align="top" height="24" src="./img/qss.svg">. Not sure you need it, [URL API](https://developer.mozilla.org/en-US/docs/Web/API/URL) support is good. (Routers and URL Utils / Reactive Programming)
- awesome-list - qss
README
# qss [![Build Status](https://travis-ci.org/lukeed/qss.svg?branch=master)](https://travis-ci.org/lukeed/qss)
> A tiny (305B) browser utility for stringifying a query Object.
You should only consider using this within a browser context since Node's built-in [`querystring.stringify`](https://nodejs.org/api/querystring.html#querystring_querystring_stringify_obj_sep_eq_options) is [much faster](#benchmarks) and _should be_ used in a Node environment! An ideal use case is serializing a query object before an API request is sent.
This module exposes three module definitions:
* **ES Module**: `dist/qss.mjs`
* **CommonJS**: `dist/qss.js`
* **UMD**: `dist/qss.min.js`## Install
```
$ npm install --save qss
```## Usage
```js
import { encode, decode } from 'qss';encode({ foo:'hello', bar:[1,2,3], baz:true });
//=> 'foo=hello&bar=1&bar=2&bar=3&baz=true'encode({ foo:123 }, '?');
//=> '?foo=123'encode({ bar:'world' }, 'foo=hello&');
//=> 'foo=hello&bar=world'decode('foo=hello&bar=1&bar=2&bar=3&baz=true');
//=> { foo:'hello', bar:[1,2,3], baz:true };
```## API
### qss.encode(params, prefix)
Returns: `String`Returns the formatted querystring.
#### params
Type: `Object`The object that contains all query parameter keys & their values.
#### prefix
Type: `String`
Default: `''`An optional prefix. The stringified `params` will be appended to this value, so it must end with your desired joiner; eg `?`.
> **Important:** No checks or validations will run on your `prefix`. Similarly, no character is used to "glue" the query string to your `prefix` string.
### qss.decode(query)
Returns: `Object`Returns an Object with decoded keys and values.
Repetitive keys will form an Array of its values. Also, `qss` will attempt to typecast `Boolean` and `Number` values.
#### query
Type: `String`The query string, without its leading `?` character.
```js
qss.decode(
location.search.substring(1) // removes the "?"
);
```## Benchmarks
> Running Node v10.13.0
***Encode***
```
qss x 1,112,341 ops/sec ±0.24% (96 runs sampled)
native x 5,303,246 ops/sec ±0.76% (95 runs sampled)
querystringify x 950,501 ops/sec ±0.76% (96 runs sampled)
query-string x 347,603 ops/sec ±1.05% (92 runs sampled)
qs x 733,449 ops/sec ±0.62% (97 runs sampled)
```***Decode***
```
qss x 443,667 ops/sec ±0.17% (95 runs sampled)
native x 189,194 ops/sec ±0.44% (94 runs sampled)
querystringify x 282,169 ops/sec ±0.26% (96 runs sampled)
query-string x 191,334 ops/sec ±0.71% (95 runs sampled)
qs x 168,165 ops/sec ±0.41% (93 runs sampled)
```## License
MIT © [Luke Edwards](https://lukeed.com)