Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codex-team/ajax
Just another AJAX requests helper
https://github.com/codex-team/ajax
ajax file-upload uploader
Last synced: 2 months ago
JSON representation
Just another AJAX requests helper
- Host: GitHub
- URL: https://github.com/codex-team/ajax
- Owner: codex-team
- License: mit
- Created: 2017-10-27T01:28:12.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-11-10T06:59:55.000Z (about 1 year ago)
- Last Synced: 2024-11-07T09:49:17.518Z (3 months ago)
- Topics: ajax, file-upload, uploader
- Language: JavaScript
- Homepage:
- Size: 884 KB
- Stars: 33
- Watchers: 8
- Forks: 10
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# AJAX
Module for async requests on a native JavaScript for a browser.
> Package has been renamed from `codex.ajax` to `@codexteam/ajax`
## Features
- zero-dependencies
- Promises based
- custom callback for a **progress** event
- easy-to-use `transport` method: ask user for a file(s) and upload it
- `object`, `FormData` or `HTMLFormElement` data is being supported## Installation
You can install this package via NPM or Yarn
```shell
npm install @codexteam/ajax
``````shell
yarn add @codexteam/ajax
```Require package on your script page.
```javascript
const ajax = require('@codexteam/ajax');
```Also you can get this module [from CDN](https://unpkg.com/@codexteam/ajax) or download a [bundle file](dist/main.js) and use it locally.
## Usage
There are a few public functions available to be used by user. All of them return Promise.
- [ajax.get()](#ajaxget) — wrapper for a GET request
- [ajax.post()](#ajaxpost) — wrapper for a POST request
- [ajax.request()](#ajaxrequest) — main function to make requests (GET, POST, HEAD, PUT, DELETE, ...)
- [ajax.transport()](#ajaxtransport) — ask user for a file and upload it
- [ajax.selectFiles()](#ajaxselectfiles) — ask user for a file and return files array### Callbacks format
`successCallback` and `errorCallback` have the same input object `response` as a param.
| param | type | description |
| ---------------- | --------------------- | ------------------------------------- |
| response.body | `object` or `string` | Response body parsed JSON or a string |
| response.code | `number` | Response code |
| response.headers | `object` | Response headers object |#### Example
```javascript
function successCallback(response) {
console.log('Response:', response.body);
}
``````javascript
function errorCallback(response) {
console.log(`Error code ${response.code}. Response:`, response.body);
}
```### ajax.get()
Wrapper for a GET request over an `ajax.request()` function.
| param | type | default value | description |
| ---------- | ---------- | -------------------- | -------------------------------------- |
| url | `string` | `''` | Request URL |
| data | `object` | `null` | Data to be sent |
| headers | `object` | `null` | Custom headers object |
| progress | `function` | `(percentage) => {}` | Progress callback |
| ratio | `number` | `90` | Max % of bar for uploading progress |
| beforeSend | `function` | `null` | Fire callback before sending a request |#### Example
```javascript
ajax.get({
url: '/getUserData',
data: {
user: 22
}
})
.then(successCallback)
.catch(errorCallback);
```### ajax.post()
Wrapper for a POST request over an `ajax.request()` function.
| param | type | default value | description |
| ---------- | ----------------------------------------- | ----------------------- | -------------------------------------- |
| url | `string` | `''` | Request URL |
| data | `object`, `FormData` or `HTMLFormElement` | `null` | Data to be sent |
| type | `string` | `ajax.contentType.JSON` | Header from `ajax.contentType` object |
| headers | `object` | `null` | Custom headers object |
| progress | `function` | `(percentage) => {}` | Progress callback |
| ratio | `number` | `90` | Max % of bar for *uploading* progress |
| beforeSend | `function` | `null` | Fire callback before sending a request |#### Example
Simple POST request
```javascript
ajax.post({
url: '/saveArticle',
data: {
title: 'Awesome article',
text: 'will be written later',
isPublished: false
},
/**
* Choose the content type you need
*/
// type: ajax.contentType.JSON /* (default) */
// type: ajax.contentType.URLENCODED
// type: ajax.contentType.FORM
})
.then(successCallback)
.catch(errorCallback);
```#### Example
To send any form you can pass HTMLFormElement as a `data` to `ajax.post()`.
```html
Send formfunction sendForm() {
var form = document.getElementById('form-element');
ajax.post({
url:'/addUser',
data: form
})
.then(successCallback)
.catch(errorCallback);
}```
### ajax.request()
Main function for all requests.
| param | type | default value | description |
| ---------- | -----------| -------------------- | -------------------------------------- |
| url | `string` | `''` | Request URL |
| method | `string` | `'GET'` | Request method |
| data | `object` | `null` | Data to be sent |
| headers | `object` | `null` | Custom headers object |
| progress | `function` | `(percentage) => {}` | Progress callback |
| ratio | `number` | `90` | Max % of bar for *uploading* progress |
| beforeSend | `function` | `(files) => {}` | Fire callback before sending a request |#### Example
```javascript
ajax.request({
url: '/joinSurvey',
method: 'POST',
data: {
user: 22
}
})
.then(successCallback)
.catch(errorCallback);
```### ajax.transport()
This is a function for uploading files from client.
User will be asked to choose a file (or multiple) to be uploaded. Then FormData object will be sent to the server via `ajax.post()` function.
| param | type | default value | description |
| ---------- | ---------- | -------------------- | ---------------------------------------------- |
| url | `string` | `''` | Request URL |
| data | `object` | `null` | Additional data to be sent |
| accept | `string` | `null` | Mime-types of accepted files |
| multiple | `boolean` | `false` | Let user choose more than one file |
| fieldName | `string` | `'files'` | Name of field in form with files |
| headers | `object` | `null` | Custom headers object |
| progress | `function` | `(percentage) => {}` | Progress callback |
| ratio | `number` | `90` | Max % of bar for *uploading* progress |
| beforeSend | `function` | `(files) => {}` | Fire callback with chosen files before sending |#### Example
```javascript
ajax.transport({
url: '/uploadImage',
accept: 'image/*',
progress: function (percentage) {
document.title = `${percentage}%`;
},
ratio: 95,
fieldName: 'image'
})
.then(successCallback)
.catch(errorCallback);
```#### Example
One simple button for uploading files.
```html
Upload file
```### ajax.selectFiles()
Ask user for a file (or multiple) and process it. FileList object will be returned in Promise.
| param | type | default value | description |
| ---------- | ---------- | -------------------- | ---------------------------------------------- |
| accept | `string` | `null` | Mime-types of accepted files |
| multiple | `boolean` | `false` | Let user choose more than one file |#### Example
```javascript
ajax.selectFiles({
accept: 'image/*'
})
.then(successCallback);
```## Params
List of params, their types, descriptions and examples.
* [url](#url)
* [method](#method)
* [data](#data)
* [type](#type)
* [beforeSend](#beforesend)
* [headers](#headers)
* [progress](#progress)
* [ratio](#ratio)
* [accept](#accept)
* [multiple](#multiple)
* [fieldName](#fieldname)### url `string`
Target page URL. By default current page url will be used.
`/user/22`, `/getPage`, `/saveArticle`
### method `string`
> Used in `ajax.request()` function only
Request method.
`GET`, `POST`
Read more about available request methods methods on the [page](https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods) at developer.mozilla.org.
### data `object|FormData|HTMLFormElement`
You can pass data as `object`, `FormData` or `HTMLFormElement`.
Data will be encoded automatically.
```javascript
ajax.request({
url: '/joinSurvey',
method: 'POST',
data: {user: 22}
})
.then(successCallback)
.catch(errorCallback);
``````javascript
ajax.request({
url: '/sendForm',
method: 'POST',
data: new FormData(document.getElementById('my-form'))
})
.then(successCallback)
.catch(errorCallback);
```> For `ajax.get()` you can pass `object` data
```javascript
ajax.get({
url: '/getUserData',
data: {
user: 22
}
})
.then(successCallback)
.catch(errorCallback);
```is the same as
```javascript
ajax.get({
url: '/getUserData?user=22'
})
.then(successCallback)
.catch(errorCallback);
```> For `ajax.transport()` should pass `object` data if it is necessary
You can send additional data with files.
```javascript
ajax.transport({
url: '/uploadImage',
accept: 'image/*',
data: {
visible: true,
caption: 'Amazing pic'
},
fieldName: 'image'
})
.then(successCallback)
.catch(errorCallback);
```### type `string`
Specify the content type of data to be encoded (by ajax module) and sent.
You can get value for this param from `ajax.contentType` object. Data will be encoded that way.
| ajax.contentType | value |
| ---------------- | -------------------------------------------------- |
| JSON | `application/json; charset=utf-8` |
| URLENCODED | `application/x-www-form-urlencoded; charset=utf-8` |
| FORM | `multipart/form-data` |```javascript
const params = {
// ...
type: ajax.contentType.JSON
// type: ajax.contentType.URLENCODED
// type: ajax.contentType.FORM
};
```### headers `object`
Object of custom headers which will be added to request.
```javascript
headers = {
'authorization': 'Bearer eyJhbGciJ9...TJVA95OrM7h7HgQ',
// ...
}
```### progress `function`
Almost all requests have responses. To show a correct progress for a call we need to combine a request progress (uploading) and a response progress (downloading). This ajax module uses one `progress` callback for it.
```javascript
/**
* @param {number} percentage - progress value from 0 to 100
*/
var progressCallback = function progressCallback(percentage) {
document.title = `${percentage}%`;
};
```Check out `ratio` param to show progress more accurate.
### ratio `number`
> Used with `progress` param
Value should be in the `0`-`100` interval.
If you know that some requests may take more time than their responses or vice versa, you can set up a `ratio` param and define a boundary between them on the progress bar.
For example if you want to show progress for a file uploading process, you know that uploading will take a much more time than downloading response, then pass bigger ratio (~95). When you want to download big file — use smaller ratio (~5).
![](./assets/ratio-example.gif)
### accept `string`
> Used in `ajax.transport()` function only
String of available types of files to be chosen by user.
`*/*` — any files (default)
`image/*` — only images
`image/png, image/jpg, image/bmp` — restrict accepted types
Read more about MIME-types on the [page](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types) at developer.mozilla.org.
### multiple `boolean`
> Used in `ajax.transport()` function only
`false` by default. User can choose only one file.
If you want to allow user choose more than a one file to be uploaded, then pass a `true` value.
### fieldName `string`
> Used in `ajax.transport()` function only
Name of data field with the file or array of files.
`files` by default.