/qps-utils

An elegant way to parse and manipulate query-params in javascript.

Primary LanguageHTMLMIT LicenseMIT

qps-utils

All Contributors

🔥 An elegant way to parse and manipulate query-params in javascript. 🔥

Installation

npm install --save qps-utils or yarn add qps-utils

Demo

Try it out here:
Edit qps-utils-demo

Usage

import qpsUtils from 'qps-utils';

1) Construct a query param url from an object

const params = {
  'id': '341',
  'name': 'john',
  'color': 'purple'
};

const url = qpsUtils.construct(params);

console.log(url); //prints: 'id=341&name=john&color=purple'

2) Construct a complete url from an object by specifying the baseUrl

const params = {
  'id': '341',
  'name': 'john',
  'color': 'purple'
};

const url = qpsUtils.baseUrl('https://example.com')
                .construct(params);

console.log(url);
//prints: 'https://example.com?id=341&name=john&color=purple'

3) Construct the query params string dynamically

const url = qpsUtils
  .add('mode', 'production')
  .add('version', '1.0.0')
  .construct();

console.log(url);
//prints: 'mode=production&version=1.0.0'

4) With baseUrl:

const url = qpsUtils
  .baseUrl('https://www.example.com')
  .add('mode', 'production')
  .add('version', '1')
  .add('public', 'yes')
  .construct();

console.log(url);
//prints: 'https://www.example.com?mode=production&version=1&public=yes'

5) Parse a valid URL and retrive its query params as a map (javascript object)

const url =
  'https://example.com?mode=production&version=1&public=true';

const params = qpsUtils.parse(url)
                .params().map();

console.log(params);
// { 'mode': 'production', 'version': '1', 'public': true }

6) Get an individual value for a given key

const url =
  'https://example.com?mode=production&version=1&public=true';

const isPublic = qpsUtils.parse(url)
                .params().get('public');

console.log(isPublic);
// prints: true

7) Add new keys to the url

const url =
  'https://example.com?mode=production&version=1&public=true';

const updatedUrl = qpsUtils.parse(url)
                    .params()
                    .add('license', 'MIT')
                    .add('stars', 0)
                    .construct();

console.log(updatedUrl);
// prints: https://example.com?mode=production&version=1&public=true&license=MIT&stars=0

Note: If any existing key present, calling add() function updates that existing key's value


8) Remove keys from the URL

const url =
  'https://example.com?mode=production&version=1&public=true';

const updatedUrl = qpsUtils.parse(url)
                    .params()
                    .add('license', 'MIT')
                    .add('stars', 0)
                    .remove('mode')
                    .remove('version')
                    .construct();

console.log(updatedUrl);
// prints: https://example.com?&public=true&license=MIT&stars=0

9) Update the baseUrl itself

const url =
  'https://example.com?mode=production&version=1&public=true';

const updatedUrl = qpsUtils.parse(url)
                    .params()
                    .add('license', 'MIT')
                    .add('stars', 0)
                    .remove('mode')
                    .remove('version')
                    .changeBaseUrl('https://qps-utils.github.io')
                    .construct();

console.log(updatedUrl);
// prints: https://qps-utils.github.io?&public=true&license=MIT&stars=0

API

qpsUtils

An object that exposes these functions: add(), baseUrl(), construct(), parse()


1) Syntax: qpsUtils.add( string: key , string: value )

Description

Internally maintains the url by adding the key & value in this format: "key=value" and returns a handle. Subsequent calls to this method appends key & value to the url string.

Parameters

{string} key, {string} value - (required)

Returns

{object} handle - Exposes two functions add(), construct()


2) Syntax: qpsUtils.baseUrl( string: url )

Description

Sets the baseUrl and returns a handle. Using that handle's add method, query parameters can be appended and with construct method, the complete url can be obtained.

Parameters

{string} : baseUrl - (required) A string that represents the endpoint/baseUrl.

Returns

{object} handle - Exposes two functions add(), construct()


3) Syntax: qpsUtils.construct( object: paramsObj )

Description

Constructs the query param url from the given javascript object.

Parameters

{object} : paramsObject - (optional) An object with keys & values with which the url is formed.

Returns

{string} : url - representing query params.


4) Syntax: qpsUtils.parse( string: url )

Description

Reads the given url and internally constructs a map of its query parameters, if any available.

Parameters

{string} : url - (required) Url with query parameters that needs to be manipulated

Returns

{object} : handle - Exposes two functions: baseUrl(), params()


5) Syntax: qpsUtils.parse( string: url ).baseUrl()

Description

Returns the base URL string in the input that is passed to the parse() function.

Parameters

None

Returns

{string} : baseUrl - substring of the url string from the beginning till the point where '?' is found.


6) Syntax: qpsUtils.parse( string: url ).params()

Description

Returns a handle that allows manipulation of the url which was passed to parse() function.

Parameters

None

Returns

{object} : handle - Exposes these functions: map(), get(), add(), remove(), changeBaseUrl(), construct()


7) Syntax: qpsUtils.parse( string: url ).params().map()

Description

Returns an object that represents the query parameters in the url string given to parse() function

Parameters

None

Returns

{object} : queryParams - Javascript object which the keys & values represent the keys & values in the url query parameters


7) Syntax: qpsUtils.parse( string: url ).params().get( string: key )

Description

Returns a string which is the value for the given key as per the input url.

Parameters

{string}: key - A string that represents the key as query params in the url.

Returns

{string} : value - A string that represents the value for the given key in the input url. If key not present, returns the empty string.


8) Syntax: qpsUtils.parse( string: url ).params().add( string: key , string: value )

Description

Adds the new pair of query params to the map maintained internally. If the key was already present, it replaces the old value with the new value passed.

Parameters

{string} key, {string} value - (required)

Returns

{object} : handle - which exposes the same set of functions like the one returned by params() function: map(), get(), add(), remove(), changeBaseUrl(), construct()


9) Syntax: qpsUtils.parse( string: url ).params().remove( string: key )

Description

Removes the key, value pair from the map maintained internally.

Parameters

{string} key, {string} value - (required)

Returns

{object} : handle - which exposes the same set of functions like the one returned by params() function
map(), get(), add(), remove(), changeBaseUrl(), construct()


10) Syntax: qpsUtils.parse( string: url ).params().changeBaseUrl( string: newUrl )

Description

Updates the baseUrl with the new one.

Parameters

{string} newUrl - (required)

Returns

{object} : handle - which exposes the same set of functions like the one returned by params() function:
map(), get(), add(), remove(), changeBaseUrl(), construct()

Contributors ✨

Thanks goes to these wonderful people (emoji key):

bautistaaa
bautistaaa

🚇 ⚠️ 💻
Tiago Santos Da Silva
Tiago Santos Da Silva

💻
Jihoon Yang
Jihoon Yang

💻

This project follows the all-contributors specification. Contributions of any kind welcome!