Promise encapsulation wx.request method

Promise encapsulation wx.request method

The previous article introduced the implementation method of using Promise to encapsulate the small program wx.request. This article focuses on the method of using promise to encapsulate wx.request. The specific content is as follows:

Why encapsulate wx.request?

Because when we request an interface, sometimes we request multiple APIs of an interface. If we do not use encapsulation, then writing code will become cumbersome and will also cause performance problems.

Encapsulation will facilitate our writing, improve user experience and facilitate code modification.

Why use promises for encapsulation choices?

When we are writing WeChat applet, when we write wx.request, I think everyone must be familiar with this writing method, which is similar to the writing method of $.ajax. We must be familiar with the encapsulation of $.ajax, so it is not difficult for us to associate it with promise. And our WeChat applet supports es6 syntax, so promise is a good encapsulation choice.

How to encapsulate wx.request?

Now that we have found the reason and tools for encapsulation, the next step is to encapsulate the tricky thing wx.request. First, create a file in our development tool

We wrap it in a large folder and process the contents separately.

insert image description here

First, in our fetch.js file, we use promise to encapsulate wx.request:

//promise encapsulates wx.request
    module.exports=(url,data,method)=>{
        //Define promise first
        let promise = new Promise((resolve, reject) => {
            wx.request({
                url:url,
                data:data,
                method:method,
 
                //Execute success(res){
                    resolve(res)
                },
 
                //Execute fail(err){
                    reject(err)
                },
    })
    })
                //Push the promise to return promise
    }

Then, in our api.js file, we can put everything we need to request here for unified management:

//Interface managementmodule.exports={
    "banner":"/h8/home/multidata"
}

Finally, in our http.js file, we centralize it and use it:

//Introduce file const api=require("./api")
    const fetch = require("./fetch")
 
//Define the path let baseUrl="http://123.207.32.32:8000/api"
 
//Export content function banner(){
        return fetch(baseUrl+api.banner,{},'get')
    }
 
    module.exports={
        banner
    }

After encapsulation, we need to import it in the global app.js before we can use it:

  const http = require('./http/http.js')
 
    App({
      http,
    })

Use in the file:

    //Introduce app
    const app = getApp()
 
    Page({
      data: {
       list:[]
      }
 
    onLoad: function () {
        app.http.banner().then(res)=>{
            this.setData({
                list:res.data.data.banner.list        
        })
            }
    }

This is the end of this article about promise encapsulation of wx.request. For more relevant promise encapsulation of wx.request content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • How to use Promise to encapsulate the wx.request applet

<<:  How to view Linux ssh service information and running status

>>:  MySQL 8.0.11 installation summary tutorial diagram

Recommend

Summary of nginx configuration location method

location matching order 1. "=" prefix i...

Summary of Binlog usage of MySQL database (must read)

I won't go into details about how important b...

Detailed explanation of the available environment variables in Docker Compose

Several parts of Compose deal with environment va...

Use of Linux read command

1. Command Introduction The read command is a bui...

How to implement adaptive container with equal aspect ratio using CSS

When developing a mobile page recently, I encount...

MySQL installation diagram summary

MySQL 5.5 installation and configuration method g...

Detailed explanation of the failure of MySQL to use UNION to connect two queries

Overview UNION The connection data set keyword ca...

Solutions to the problem of table nesting and border merging

【question】 When the outer table and the inner tab...

Detailed steps for deploying Tomcat server based on IDEA

Table of contents Introduction Step 1 Step 2: Cre...

HTML unordered list bullet points using images CSS writing

Create an HTML page with an unordered list of at l...