【js http client 封装】

client

// http.js
import axios from 'axios';
import { stringify } from 'qs';

export default class http {
    constructor(baseURL) {
        this.baseURL = baseURL;
        this.apiClient = axios.create({
            baseURL: this.baseURL,
            timeout: 10000
        });
        // this.defaults.headers.post['Content-Type'] = 'application/json';
        this.apiClient.interceptors.request.use(config => {
            // 在发送请求前可以做一些处理
            return config;
        }, error => {
            return Promise.reject(error);
        });
        this.apiClient.interceptors.response.use(response => {
            // 在响应到达客户端前可以做一些处理
            return response;
        }, error => {
            return Promise.reject(error);
        });
    }
    get(url, params = {}, config = {}) {
        return this.apiClient.get(url, {
            params,
            ...config
        });
    }

    post(url, data = {}, config = {}) {
        if (this.apiClient.defaults.headers.post['Content-Type'] === 'application/x-www-form-urlencoded') {
            data = stringify(date);
        } else {
            this.set_header_post_content_type_json();
            data = JSON.stringify(data);
        }
        return this.apiClient.post(url, data, config);
    }

    put(url, data = {}, config = {}) {
        return this.apiClient.put(url, data, config);
    }

    delete(url, params = {}, config = {}) {
        return this.apiClient.delete(url, {
            params,
            ...config
        });
    }

    set_header_common(key, value) {
        this.apiClient.defaults.headers.common[key] = value;
    }
    set_header_get(key, value) {
        this.apiClient.defaults.headers.get[key] = value;
    }
    set_header_post(key, value) {
        this.apiClient.defaults.headers.post[key] = value;
    }
    set_header_post_content_type_json() {
        this.apiClient.defaults.headers.post['Content-Type'] = 'application/json';
    }
    set_header_post_content_type_form() {
        this.apiClient.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
    }
};




};

调用client

// test.js
import http from "./http.js";

const api = new http('https://www.baidu.com');
const resp = await api.get('/');
console.log(resp.data);

const resp_login = await api.post('/user/login/', {'username': 'username', 'password': 'password'});
console.log(resp_login.status);
console.log(resp_login.data);
// console.log(resp_login.headers);
// console.log(resp_login.data);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值