Skip to content
This repository has been archived by the owner on Sep 22, 2020. It is now read-only.

Latest commit

 

History

History
100 lines (59 loc) · 2.7 KB

README.md

File metadata and controls

100 lines (59 loc) · 2.7 KB

Params.js takes the suck out of window.location.search.

Params.js is class that has an API for getting, setting, and unsetting URL query params without destroying any existing query params.

It doesn't do anything fancy like serializing nested objects or attempting to preserve a particular param order.

Building

To watch the coffee file for changes and build the js:

coffee -wcb params.coffee

Testing

Testing uses vows. npm install vows -g then run vows.

API

First, make an instance of Params. By default, it uses window.location, but you can pass an object the constructor that resembles 'window.location'.

// plain
var params = new Params();

// with a stubbed location object
var stubbedLocation = {
  href: cheapcadaversURL,
  search: "?rick=moranis&bumblebee=tuna&hash[some_key]=someValue",
  protocol: "http:",
  host: "www.cheapcadavers.com",
  pathname: "/"
};
var fakedParams = new Params(stubbedLocation);

Instance Methods

get(key)

Returns the value of the key

set(object or key, value)

If an object is the argument, then it will copy all of the object's properties to the params.

If a key and value is passed, then it will make a new param with the given key and value.

It returns the params object, making it chainable.

unset(key)

Removes the key and value pair from the params.

It returns the params object, it's also chainable.

href()

Returns a string that is a full URL, similar to window.location.href.

search()

Returns a string that is just the params, in a serialized form, similar to window.location.search.

object()

Returns a shallow copy of the internal _params object.

validate(string)

Useful to test if the given string resembles a valid location.search object. Returns true if it passes.

Static Methods

Params.parse(string)

Creates and returns an object from the query params in the string.

Change Log:

v0.6.0 - November 7, 2012 - Converts test suite from qunit to vows. Added the ability to save arrays, serialize arrays like: foo=a&foo=b, and Params.parse can interpret serialized arrays.

v0.5.1 - April 10, 2012 - Params.parse will call decodeURIComponent on values.

v0.5.0 - November 29, 2011 - set and unset methods return the params object, making it chainable.

v0.4.0 - September 26, 2011 - Added object() instance method to return an object of the params.

v0.3.1 - September 14, 2011 - Params.parse() returns an empty object if it gets an empty string.

v0.3.0 - September 14, 2011 - Using prototypes instead of closures to reduce memory footprint. Added Params.parse() static method.

v0.2.1 - August 17, 2011 - Added validate() instance method.