ts通过class类封装axios

一、axios 安装

npm i axios -S

二、HttpRequest类封装

// 文件 utils/axios.ts

import axios, {AxiosInstance, AxiosRequestConfig} from 'axios'

class HttpRequest {
    private readonly baseUrl: string;
    constructor() {
        this.baseUrl = 'http://localhost:3000'
    }
    getInsideConfig() {
        const config = {
            baseURL: this.baseUrl,
            headers: {
                //
            }
        }
        return config
    }

// 请求拦截
    interceptors(instance: AxiosInstance, url: string | number | undefined) {
        instance.interceptors.request.use(config => {
            // 添加全局的loading..
            // 请求头携带token
            return config
        }, (error: any) => {
            return Promise.reject(error)
        })
        //响应拦截
        instance.interceptors.response.use(res => {
            //返回数据
            const {data} = res
            console.log('返回数据处理',res)
            return data
        }, (error: any) => {
            console.log('error==>',error)
            return Promise.reject(error)
        })
    }

    request(options: AxiosRequestConfig) {
        const instance = axios.create()
        options = Object.assign(this.getInsideConfig(), options)
        this.interceptors(instance, options.url)
        return instance(options)
    }
}

const http = new HttpRequest()
export default http

三、接口方法封装


// 文件api/index.ts
import http  from '../utils/axios'

export const menuList =()=>{
    return http.request({
        url: '/users/menuList',
        method: 'get'
    })
}

四、页面使用

import {menuList} from '../api/index'

getMenuList(){
    menuList().then(res=>{
        console.log(res)
    })

}
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐