Ant Design Pro,请求接口Network的Preview有值,但返回的response值是undefined

  •  问题:Ant Design Pro,请求接口,Network的Preview有值,但返回的response值是undefined,Preview是字符串不是json

 

// models/login.js中
effects: {
  *getData({ payload }, { call }) {
    const response = yield call(getData);
    console.log(_data); // undefined
    return response;
  }
}

// 组件中
getData= async() {
  const response = await this.props.dispatch({
    type: 'login/getData',
  });
  console.log(response); // undefined
}

  •  分析:由于组件和models中都response都是undefined,那么首先想到,可能是request.js中请求返回的response有问题,操作response的地方出错。打开utils/request.js,发现return的fetch方法中默认 return response.json(),而浏览器Network上显示的Preview是字符串,处理字符串应该用 return response.text()。此步骤就已经出错,所以models中拿到的结果就是undefined。
// 默认request
return fetch(url, newOptions)
    .then(checkStatus)
    .then(response => cachedSave(response, hashcode))
    .then(response => {
      if (newOptions.method === 'DELETE' || response.status === 204) {
        return response.text();
      }
      return response.json();
    })

  • 解决办法:让后端将返回的数据格式由字符串改为json。或者前端修改utils/request.js,让其return response.text()来处理字符串

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值