How to customize alova's request adapter

Scott Hu - Nov 23 '23 - - Dev Community

alova is a lightweight request strategy library designed to simplify the management and use of interfaces. By simply configuring parameters, you can implement complex requests such as sharing requests, paging requests, form submissions, breakpoint resumption, etc., without writing a lot of code, improving development efficiency, application performance, and reducing server pressure.

When using alova to send network requests, we often need to add some information to the request header, such as authentication tokens, public parameters, etc. alova provides two ways to configure request headers at global and individual request granularities. The method of adding request headers is very similar to axios.

Get to know the request adapter

Remember how to create an Alova instance?

const alovaInstance = createAlova({
   // ...
   requestAdapter: GlobalFetch()
});
Enter fullscreen mode Exit fullscreen mode

Yes, requestAdapter is a request adapter. Internal request sending and receiving will rely on the request adapter. GlobalFetch manages requests through the fetch api. In most cases we can use it, but whenWhen alova is running in an environment where the fetch api is not available (such as app, applet), you need to replace a request adapter that supports the current environment.

Write an own request adapter

So how to customize a request adapter? Very simple, it is actually a function. This function will be called every time a request is made, and an object will be returned. This object contains items such as url, method, data, headers, timeout, etc. Request related data collections. Although there are many fields, we only need to access the data we need.

Request adapter structure

The request adapter will receive the request-related parameters and the method instance currently being requested, and return a collection of response-related functions.

function CustomRequestAdapter(requestElements, methodInstance) {
   // send request...
   return {
     async response() {
       // ...return response data
     },
     async headers() {
       // Asynchronous function that returns response headers
     },
     abort() {
       //Interrupt request, this function will be triggered when abort is called externally
     },
     onDownload(updateDownloadProgress) {
       //Download progress information, updateDownloadProgress is continuously called internally to update the download progress.
     },
     onUpload(updateUploadProgress) {
       //Upload progress information, updateUploadProgress is continuously called internally to update the upload progress.
     }
   };
}
Enter fullscreen mode Exit fullscreen mode

Request parameter details

requestElements

Relevant elements of the send request, including the following data.

interface RequestElements {
   //Request url, get parameters are included in it
   readonly url: string;

   // Request type, such as GET, POST, PUT, etc.
   readonly type: MethodType;

   //Request header information, object
   readonly headers: Arg;

   //Request body information
   readonly data?: RequestBody;
}
Enter fullscreen mode Exit fullscreen mode

methodInstance

The method instance of the current request

Return parameter details

response (required)

An asynchronous function that returns the response value, which will be passed to the global response interceptor (responded);

headers (required)

An asynchronous function, the response header object returned by the function will be passed to the transformData conversion hook function of the Method instance;

abort (required)

A common function, which is used for interrupt requests. When the abort function is called in the Manual Interrupt Request chapter, the function that actually triggers the interrupt request is this interrupt function;

onDownload(optional)

A normal function that receives a callback function that updates the download progress. Customize the frequency of progress updates within this function. In this example, it simulates an update every 100 milliseconds. The updateDownloadProgress callback function receives two parameters, the first parameter is the total size, and the second parameter is the downloaded size;

onUpload(optional)

A normal function that receives a callback function that updates the upload progress. Customize the frequency of progress updates within this function. In this example, it simulates an update every 100 milliseconds. The updateUploadProgress callback function receives two parameters, the first parameter is the total size, and the second parameter is the uploaded size;

(Case) XMLHttpRequest request adapter

The following is an example of an adapter that sends requests through XMLHttpRequest. It is mainly used to demonstrate how to write the adapter. The code is incomplete and cannot be run.

function XMLHttpRequestAdapter(requestElements, methodInstance) {
   // Deconstruct the data needed
   const { url, type, data, headers } = config;

   // send request
   const xhr = new XMLHttpRequest();
   xhr.open(type, url);
   for (const key in headers) {
     xhr.setRequestHeader(key, headers[key]);
   }
   const responsePromise = new Promise((resolve, reject) => {
     xhr.addEventListener('load', event => {
       // Process response data
       resolve(/* ... */);
     });
     xhr.addEventListener('error', event => {
       // Handle request errors
       reject(/* ... */);
     });
   });

   xhr.send(JSON.stringify(data));

   return {
     // Asynchronous function that returns response data
     response: () => responsePromise,

     // Asynchronous function that returns response headers
     headers: () => responsePromise.then(() => xhr.getAllResponseHeaders()),
     abort: () => {
       xhr.abort();
     },

     //Download progress information, updateDownloadProgress is continuously called internally to update the download progress.
     onDownload: updateDownloadProgress => {
       xhr.addEventListener('progress', event => {
         //Data receiving progress
         updateDownloadProgress(event.total, event.loaded);
       });
     },

     //Upload progress information, updateUploadProgress is continuously called internally to update the upload progress.
     onUpload: updateUploadProgress => {
       xhr.upload.onprogress = event => {
         updateUploadProgress(event.total, event.loaded);
       };
     }
   };
}
Enter fullscreen mode Exit fullscreen mode

Complete XMLHttpRequest request adapter code click here to view the source code.

End

The above is how to write alova's custom request adapter, which can flexibly handle different request header setting requirements.

If you have any usage questions, you can join the following group chat for consultation, or you can publish Discussions in github repository. If you encounter problems, please also post in github's issues, we will solve it as soon as possible.

You are also welcome to contribute, please go to Contribution Guide.

The following is a tutorial for some chapters. If you want to learn more about the usage of alovajs, please come to alova official website to learn.

. . . . . . . . . . . . . . . . . . . . . . . . .