A simple to use http client built on ES6 fetch and RxJS.
Version 8.0.0 is the latest stable version.
As of version 8.0.0, support for non-JSON bodies has been added. This means that the request 'Content-Type' header no longer defaults to the value 'application/json', which means you will need to provide this header in the request config for each request with a JSON body or in a RequestInterceptor.
You can use NPM or Yarn to install this package
yarn add rxjs-http-client
npm i rxjs-http-client
Using rxjs-http-client is very simple.
To get started you are required to create a new instance of the RxJSHttpClient class as shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
}
The get method provides you with the ability to make a HTTP GET request.
This method has two parameters, the first parameter is the request url and the second optional parameter is the HTTP config object.
This method returns an observable container a HTTP response object.
Example of basic usage is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
getRequest() {
this._http.get('some-url')
.pipe(
mergeMap((response) => response.json())
)
.subscribe((response) => {
console.log(response)
})
}
}
The post method provides you with the ability to make a HTTP POST request.
This method has two parameters, the first parameter is the request url and the second parameter is the HTTP config object.
This method returns an observable container a HTTP response object.
Example of basic usage is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
postRequest() {
const request = {
body: {
some: 'data'
},
headers: {
'Content-Type': 'application/json'
}
}
this._http.post('some-url', request)
.pipe(
mergeMap((response) => response.json())
)
.subscribe((response) => {
console.log(response)
})
}
}
The put method provides you with the ability to make a HTTP PUT request.
This method has two parameters, the first parameter is the request url and the second parameter is the HTTP config object.
This method returns an observable container a HTTP response object.
Example of basic usage is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
putRequest() {
const request = {
body: {
some: 'data'
},
headers: {
'Content-Type': 'application/json'
}
}
this._http.put('some-url', request)
.pipe(
mergeMap((response) => response.json())
)
.subscribe((response) => {
console.log(response)
})
}
}
The patch method provides you with the ability to make a HTTP PATCH request.
This method has two parameters, the first parameter is the request url and the second parameter is the HTTP config object.
This method returns an observable container a HTTP response object.
Example of basic usage is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
patchRequest() {
const request = {
body: {
some: 'data'
},
headers: {
'Content-Type': 'application/json'
}
}
this._http.patch('some-url', request)
.pipe(
mergeMap((response) => response.json())
)
.subscribe((response) => {
console.log(response)
})
}
}
The delete method provides you with the ability to make a HTTP DELETE request.
This method has two parameters, the first parameter is the request url and the second parameter is the HTTP config object.
This method returns an observable container a HTTP response object.
Example of basic usage is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient();
}
deleteRequest() {
const request = {
body: {
some: 'data'
},
headers: {
'Content-Type': 'application/json'
}
}
this._http.delete('some-url', request)
.pipe(
mergeMap((response) => response.json())
)
.subscribe((response) => {
console.log(response)
})
}
}
The HTTP Config Object is a interface that is used as the second parameter to all the methods and is only optional on the get method. The Http Config Object contains the following properties that are all optional:
- mode - Contains the mode of the request (e.g., cors, no-cors, same-origin, navigate.)
- cache - Contains the cache mode of the request (e.g., default, reload, no-cache).
- credentials - Contains the credentials of the request (e.g., "omit", "same-origin", "include"). The default is "same-origin".
- headers - Contains the key value pairs (object) of the request headers (default 'Content-Type' header is 'application/json')
- redirect - Contains the mode for how redirects are handled. It may be one of follow, error, or manual.
- referrer - Contains the referrer of the request (e.g., client).
- body - Contains the request body to send in the request
The HTTP Response Object is a interface that is returned from all of the HTTP client methods. The Http Response Object contains the following properties and methods:
- headers - Contains a the standard JS Headers Class
- ok - Contains a boolean stating whether the response was successful (status in the range 200-299) or not.
- redirected - Indicates whether or not the response is the result of a redirect; that is, its URL list has more than one entry.
- status - Contains the status code of the response (e.g., 200 for a success).
- statusText - Contains the status message corresponding to the status code (e.g., OK for 200).
- trailer - Contains a Observable resolving to a Headers object associated with the response with Response.headers for values of the HTTP Trailer header.
- type - Contains the type of the response (e.g., basic, cors).
- url - Contains the URL of the response.
- arrayBuffer() - Takes a Response stream and reads it to completion. It returns a Observable that resolves with an ArrayBuffer.
- blob() - Takes a Response stream and reads it to completion. It returns a Observable that resolves with a Blob.
- formData() - Takes a Response stream and reads it to completion. It returns a Observable that resolves with a FormData object.
- json() - Takes a Response stream and reads it to completion. It returns a Observable that resolves with the result of parsing the body text as JSON.
- text() - Takes a Response stream and reads it to completion. It returns a Observable that resolves with a USVString (text).
It is possible to intercept a HTTP request by providing the HTTP client with an array of HTTP request interceptors. The request interceptors will run in the order they are provided in the array.
In order for a request interceptor to work correctly it must adhere to the following interface: IHttpInterceptor.
It is possible to intercept a HTTP response by providing the HTTP client with an array of HTTP response interceptors. The response interceptors will run in the order they are provided in the array.
In order for a response interceptor to work correctly it must adhere to the following interface: IHttpInterceptor.
The IHttpInterceptor interface is the interface which all HTTP interceptors must adhere to in order to work correctly. This interface consists of one method, the intercept method.
The intercept method has one parameter that is a HttpRequest if it is a request interceptor or a HttpResponse if it is a response interceptor.
The intercept method must return a HttpRequest if it is a request interceptor or a HttpResponse if it is a response interceptor.
An example of a http request interceptor is shown below:
class ExampleRequestInterceptor {
intercept(request) {
const newRequest = request.clone();
newRequest.headers = {
...request.headers,
testing: 'example adding a header to the request',
};
return newRequest;
}
}
An example of a http response interceptor is shown below:
class ExampleResponseInterceptor {
intercept(response) {
const newResponse = response.clone();
newResponse.status = 404;
return newResponse;
}
}
The first optional parameter of the RxjsHttpClient is an array of request interceptors and the second optional parameter is an array of response interceptors.
An example of a http client with just request interceptors is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient([
new ExampleRequestInterceptor()
]);
}
}
An example of a http client with request interceptors and response interceptors is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient([
new ExampleRequestInterceptor()
],
[
new ExampleResponseInterceptor()
]);
}
}
An example of a http client with just response interceptors is shown below:
class SomeClass {
_http;
constructor() {
this._http = new RxJSHttpClient([],
[
new ExampleResponseInterceptor()
]);
}
}
After passing interceptors into an instance of an RxjsHttpClient it will be used on all requests from then on but only on that instance.
The HttpRequest class is the fully mapped request that is passed to request interceptors for modification if required. It contains the following properties that can all be changed:
- url - The URL for the request
- mode - Contains the mode of the request (e.g., cors, no-cors, same-origin, navigate.)
- cache - Contains the cache mode of the request (e.g., default, reload, no-cache).
- credentials - Contains the credentials of the request (e.g., "omit", "same-origin", "include"). The default is "same-origin".
- headers - Contains the key value pairs (object) of the request headers (default 'Content-Type' header is 'application/json')
- redirect - Contains the mode for how redirects are handled. It may be one of follow, error, or manual.
- referrer - Contains the referrer of the request (e.g., client).
- body - Contains the request body to send in the request
I'd like to hear from anyone who finds any bugs/ feature request for this library, go to The issues page