MecuryJerry 2021-10-21 20:16 采纳率: 75%
浏览 39
已结题

vue复写了axios请求方法,关于不同调用的回调问题

我在一个js文件里复写了axios的四个方法,写到这我迷惑了,因为在调用的时候不管请求成功还是失败,回调的函数我也不能写成复用的,我需要针对不同调用在回调里进行不同的处理,在此请教一下各位大 神,该怎么写?

import axios from 'axios'
import { Message } from 'element-ui'
// axios请求超时时间
axios.defaults.timeout = 10000
    // 允许跨域携带cookie信息
axios.defaults.withCredentials = true
    // axios发送数据时使用json格式
    // axios.defaults.transformRequest = data => JSON.stringify(data);
    // 发送数据前进行json格式化
axios.defaults.headers['Content-Type'] = 'application/json'

let http = {
    /**
     * axios 异步请求封装方法
     * @param {路径} url String
     * @param {参数} params Object
     **/
    get: function(url, data) {
        axios({
            url: url,
            method: 'get',
            params: data
        }).then(res => {
            if (res.data.code == 200) {
                Message({
                    message: res.data.message,
                    showClose: true,
                    type: 'success',
                    duration: 1500
                })
            } else {
                Message({
                    message: res.data.status + res.data.message,
                    showClose: true,
                    type: 'warning',
                    duration: 1500
                })
            }
        }).catch(err => {
            console.log(err)
        })
    },
    /**
     * axios 异步请求封装方法
     * @param {路径} url String
     * @param {参数} data Object,请求体
     **/
    post: function(url, data) {
        axios({
            url: url,
            method: 'post',
            data: data
        }).then(res => {
            if (res.data.code == 200) {
                Message({
                    message: res.data.message,
                    showClose: true,
                    type: 'success',
                    duration: 1500
                })
            } else {
                Message({
                    message: res.data.status + res.data.message,
                    showClose: true,
                    type: 'warning',
                    duration: 1500
                })
            }
        }).catch(err => {
            console.log(err)
        })
    },
    /**
     * axios 异步请求封装方法
     * @param {路径} url String,一般将id拼在url后
     * @param {参数} data Object,请求体
     **/
    put: function(url, data) {
        axios({
            url: url,
            method: 'put',
            data: data
        }).then(res => {
            if (res.data.code == 200) {
                Message({
                    message: res.data.message,
                    showClose: true,
                    type: 'success',
                    duration: 1500
                })
            } else {
                Message({
                    message: res.data.status + res.data.message,
                    showClose: true,
                    type: 'warning',
                    duration: 1500
                })
            }
        }).catch(err => {
            console.log(err)
        })
    },
    /**
     * axios 异步请求封装方法
     * @param {路径} url String,一般将id拼在url后
     * @param {参数} params Object,一般不使用params方式传递id值
     **/
    delete: function(url, id) {
        axios({
            url: url,
            method: 'delete',
            params: id
        }).then(res => {
            if (res.data.code == 200) {
                Message({
                    message: res.data.message,
                    showClose: true,
                    type: 'success',
                    duration: 1500
                })
            } else {
                Message({
                    message: res.data.status + res.data.message,
                    showClose: true,
                    type: 'warning',
                    duration: 1500
                })
            }
        }).catch(err => {
            console.log(err)
        })
    }
}
export default http
  • 写回答

2条回答 默认 最新

  • been_ss 2021-10-21 20:21
    关注

    哈喽,可以学一下Promise

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月22日
  • 已采纳回答 10月22日
  • 创建了问题 10月21日

悬赏问题

  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误