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 Python语言实验
  • ¥15 我每周要在投影仪优酷上自动连续播放112场电影,我每一周遥控操作一次投影仪,并使得电影永远不重复播放,请问怎样操作好呢?有那么多电影看吗?
  • ¥20 电脑重启停留在grub界面,引导出错需修复
  • ¥15 matlab透明图叠加
  • ¥50 基于stm32l4系列 使用blunrg-ms的ble gatt 创建 hid 服务失败
  • ¥150 计算DC/DC变换器平均模型中的参数mu
  • ¥25 C语言代码,大家帮帮我
  • ¥15 请问以下文字内容及对应编码是用了什么加密算法或压缩算法呢?
  • ¥50 关于#html5#的问题:H5页面用户手机返回的时候跳转到指定页面例如(语言-javascript)
  • ¥15 无法使用此凭据登录,因为你的域不可用,如何解决?(标签-Windows)