axios post请求参数传递不了?

// axios.js

import axios from 'axios'
import qs from 'qs'

const service = axios.create({
  baseURL: '//askpre.hishixi.cn/api',
  timeout: 15000,
  transformRequest: [function (data) {
    data = qs.stringify({});
    return data;
  }]
})
service.defaults.withCredentials = true
// POST传参序列化
service.interceptors.request.use((config) => {
  return config
}, (error) => {
  return Promise.reject(error)
})

// 返回状态判断
service.interceptors.response.use(function (res) {
  return res.data
}, function (error) {
  return Promise.reject(error)
})

export default service

// 组件

import axios from '../plugins/axios.js'
axios.post('abc', {
  page: 1
})
阅读 2.5k
2 个回答

transformRequest对data的处理错误


const service = axios.create({
  // ...省略代码
  transformRequest: [function (data) {

    // 此处错误,你想要的是 data = qs.stringify(data); 吧
    data = qs.stringify({}); 
    
    return data;
  }]
})

另外,提个小建议:
为什么withCredentials的设置不在axios.create时直接设置呢,更一目了然。


const service = axios.create({
    // ...省略代码
    withCredentials: true
})

描述清楚点呢。。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题