0.2.0 • Published 8 years ago

ajaxed-promise v0.2.0

Weekly downloads
4
License
ISC
Repository
github
Last release
8 years ago

Ajaxed-promise

A promise based Ajax library for Node.js

Ajaxed-promise is promise based ajax library for Node.js with backward compatibility for older browsers. For the browsers that support ES6 Promises, Ajax call will return a promise. For the browsers that lacks Promises, the library will fallback to tradional Ajax calls. For browsers IE9 and below, it'll make suitable calls to get Ajax results.

The best part about this library is that the order of call doesn't change for users. Also it quite small library which is just 4Kb, or less than 2Kb when minimized, and ~860 bytes when minimized and gzipped.

Installation

Install the package by issue the command -

npm install --save ajaxed-promise

Including in code

Include the package by issuing following command

ES6 module syntax -

import ajax from 'ajaxed-promise';

Node.js module syntax -

var ajax = require('ajaxed-promise');

Usage

You can now make various AJAX requests as follows

GET

ajax(url)
    .get(data)
    .then(successCallback, failureCallback);

POST

ajax(url)
    .post(data)
    .then(successCallback, failureCallback);

PUT

ajax(url)
    .put(data)
    .then(successCallback, failureCallback);

DELETE

ajax(url)
    .delete(data)
    .then(successCallback, failureCallback);

JSONP

ajax(url)
    .jsonp()
    .then(successCallback, failureCallback);

where various attributes are

`url` (String) - URL from where data is to be retrieved
`data` (Object) - Data to be sent as a part of AJAX request (details below)
`successCallback` (Function) - Function that will be called when a data is obtained successfully from Ajax call
`failureCallback` (Function) - Function that will be called when Ajax call fails

Data Param

Sample data for Ajax request is -

{                               // [Required] Except for GET (optional) and JSONP (ignored) calls
    config: {                   // [Optional] Config data to be set for making Ajax call
        timeout: 200,           // [Optional] Timeout before Ajax request is terminated
        credentials: true,      // [Optional] Boolean to decides whether CORS requests should be made
        headers: [              // [Optional] Set Request headers for Ajax calls
            'Access-Control-Allow-Headers': '*',
            'Content-type', 'application/json; charset=UTF-8'
        ]
    },
    payload: {                  // [Reuqired] Except for GET and DELETE (ignored) calls
        urlParam: false,        // [Optional] If set to true, then payload.data is appended to URL itseld
        data: {}                // [Required] Data to be send alongwith URL
    }
}

Example

ajax('http://api.randomuser.me/')
    .get({
        payload: {
            urlParam: true,
            data: {
                results: 1
            }
        }
    })
    .then(function(data) {
        console.log(data);
    });

Know issue

  • On IE8 and below, raw response is returned. User has to parse the response himself.
0.2.0

8 years ago

0.1.2

8 years ago

0.1.1

8 years ago

0.1.0

8 years ago