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日

悬赏问题

  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 AT89C51控制8位八段数码管显示时钟。
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题