MecuryJerry 2021-10-22 14:08 采纳率: 75%
浏览 64
已结题

vue项目想复写一套axios的get,post,put,delete方法

vue项目中使用了axios去向后台请求数据,但是因为请求返回的then和catch要写的东西很多,而且每次请求都得写一次显得代码很冗余,所以我想复写四个方法,我只需要关心正确返回也就是res.status == 200即可,请问大伙我该怎么写?

// 复写前的axios
this.$axios({
        url: `${this.$api.zhishizhongxinUrl}/workbench/newinfo/rotation`,
        methods: 'get',
        params: {
          imageNew: 1,
          num: 4,
          // typeId:
        }
      }).then(res => {
        if (res.data.code == 200) {
          this.imgList = res.data.data
        } else {
          this.$message({
            duration: 1000,
            message: '新闻获取失败,错误原因:' + res.data.message,
            type: 'warn'
          })
        }
      }).catch(err => {
        this.$message({
          duration: 1000,
          message: '新闻获取失败,错误原因:' + err,
          type: 'error'
        })
      })
  • 写回答

4条回答 默认 最新

  • been_ss 2021-10-22 14:14
    关注

    哈喽,直接写成一个方法,什么请求方式直接传进来就好啦,参考一下,有用请点采纳

    /**
     * @param url 接口地址
     * @param method 请求类型 默认 get
     * @param data 数据参数
     * @param option 配置项
     */
     export function simpleRequest(url,method='get',data,option={}) {
      return ()=>{
          return new Promise((resolve, reject) => {
              http.request(Object.assign({
                  url,
                  method,
                  params: method==='get'? data: {},
                  data: method==='post'? data: {}
              },option)).then(res => {
                  resolve(res.data)
              }).catch(err => {
                  reject(err)
              })
          })
      }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)