0

axios跨域get请求返回undefined

import axios from 'axios'

export default function ajax(url = '', data = {}, type = 'GET') {
  // 返回值 Promise对象 (异步返回的数据是response.data,而不是response)
  return new Promise(function (resolve, reject) {
    // (利用axios)异步执行ajax请求
    let promise // 这个内部的promise用来保存axios的返回值(promise对象)
    if (type === 'GET') {
      // 准备 url query 参数数据
      let dataStr = '' // 数据拼接字符串,将data连接到url
      Object.keys(data).forEach(key => {
        dataStr += key + '=' + data[key] + '&'
      })
      if (dataStr !== '') {
        dataStr = dataStr.substring(0, dataStr.lastIndexOf('&'))
        url = url + '?' + dataStr
      }
      // 发送 get 请求
      promise = axios.get(url)
    } else {
      // 发送 post 请求
      promise = axios.post(url, data)
    }
    promise.then(response => {
      // 成功回调resolve()
      console.log(response.data)//这里输出有结果
      resolve(response.data)//回调后获得的结果是undefined
    })
      .catch(error => {
        // 失败回调reject()
        reject(error)
      })
  })
}

我的跨域配置
图片描述
我的js中的方法
图片描述
这是我获得的结果(第一行是回调后的输出;第二行是回调前输出,也就是上面代码块的console.log(response.data))
图片描述

我是一个新手,这是我写着玩的项目,求大佬们回答,十分感谢!!!

0 个回答

撰写答案

推广链接