axios的post请求方法---以Vue示例

Axios向后端提交数据的参数格式是json,而并非用的是form传参,post表单请求提交时,使用的Content-Type是application/x-www-form-urlencoded,而使用原生AJAX的POST请求如果不指定请求头RequestHeader,默认使用的Content-Type是text/plain;charset=UTF-8。

axios 请求配置中,transformRequest配置允许在向服务器发送前,修改请求数据。

  // `transformRequest` 允许在向服务器发送前,修改请求数据
  // 只能用在 ‘PUT‘, ‘POST‘ 和 ‘PATCH‘ 这几个请求方法
  // 后面数组中的函数必须返回一个字符串,或 ArrayBuffer,或 Stream
  transformRequest: [function (data) {
    // 对 data 进行任意转换处理

    return data;
  }],

可以使用该配置修改请求参数。

参考资料:https://www.kancloud.cn/yunye/axios/234845

如下是axios的两种方法

方法一:

this.axios({
  url: ‘/user‘,
  method: ‘post‘,
  data: {
    firstName: ‘Fred‘,
    lastName: ‘Flintstone‘
  },
  transformRequest: [function (data) {
    // Do whatever you want to transform the data
    let ret = ‘‘
    for (let it in data) {
      ret += encodeURIComponent(it) + ‘=‘ + encodeURIComponent(data[it]) + ‘&‘
    }
    return ret
  }],
  headers: {
    ‘Content-Type‘: ‘application/x-www-form-urlencoded‘
  }
})

当然可以在main.js中进行配置

// main.js

import Axios from ‘axios‘
import VueAxios from ‘vue-axios‘

const MyAxios = Axios.create({
  transformRequest: [function (data) {
    // 将数据转换为表单数据
    let ret = ‘‘
    for (let it in data) {
      ret += encodeURIComponent(it) + ‘=‘ + encodeURIComponent(data[it]) + ‘&‘
    }
    return ret
  }],
  headers: {
    ‘Content-Type‘: ‘application/x-www-form-urlencoded‘
  }
})

Vue.use(VueAxios, MyAxios)

参考链接:https://segmentfault.com/q/1010000008462977

方法二:使用qs模块/querystring模块

//import qs from ‘querystring‘
import qs from ‘qs‘
//export default{  .. }
this.axios({
  url: ‘/user‘,
  method: ‘post‘,
  data: {
      firstName: ‘Fred‘,
      lastName: ‘Flintstone‘
  },
  transformRequest: [function (data) {
    data = qs.stringify(data);
    return data;
  }],
  headers:{‘Content-Type‘:‘application/x-www-form-urlencoded‘}
  })
})

此方法操作前,需要先安装qs

npm install --save qs

参考链接:https://blog.csdn.net/shooke/article/details/76038967

原文地址:https://www.cnblogs.com/lcspring/p/10961475.html

时间: 2024-08-30 03:44:46

axios的post请求方法---以Vue示例的相关文章

深入解析Axios 常用的请求方法别名

下面小编就为大家分享一篇Axios 常用的请求方法别名,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下.如有不足之处,欢迎批评指正. Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中.常用的请求方法别名一般有: Get/post/http协议请求 执行Get请求 function get(){ return axios.get('/data.json', { params:{ id:1234 } }).then(functio

解决vue axios跨域请求发送两次问题

问题: vue axios跨域请求,在Request Headers加Authorization传递Token时,发现统一请求触发了两次,第一次是Request Method: OPTIONS请求. 原因: 跨域请求时,浏览器会首先使用OPTIONS方法发起一个预请求,判断接口是否能够正常通讯.如果通讯异常,则不会发送真正的请求,如果测试通讯正常,则开始真正的请求. 解决方法: 后台:判断请求方式是OPTIONS,则不处理: 预请求 发送真正请求  PHP解决方法 class Common ex

vue使用Axios做ajax请求

vue2.0之后,就不再对vue-resource更新,而是推荐使用axios 1. 安装 axios $ npm install axios 或 $ bower install axios 2. 在要使用的文件中引入axios import axios from 'axios' 3. 使用axios做请求 可以通过向 axios 传递相关配置来创建请求, 只有 url 是必需的.如果没有指定 method,请求将默认使用 get 方法. { // `url` 是用于请求的服务器 URL url

vue中采用axios发送post请求

这几天在使用vue中axios发送get请求的时候很顺手,但是在发送post请求的时候老是在成功的回调函数里边返回参数不存在,当时就纳闷了,经过查阅资料,终于得到了解决方案,在此做一总结: 首先我们在运用npm install axios的时候就会默认安装qs,因此我们就得将qs引入到axios中,然后需要再通过实例化一个新的axios,并且设置他的消息头为'content-type': 'application/x-www-form-urlencoded' 1 let qs = require

axios请求方法封装.

axios的使用上一般封装好对应的方法,ES6导出,直接调用,消息通知使用了ElementUI的Message组件. 这是一个封装了axios的Rest风格的工具类,包扩常用的POST,GET,PUT,DELETE, 在请求处理上使用统一的请求拦截处理.对返回的消息进行拦截预处理,有数据返回数据,没有返回消息. import axios from 'axios' import router from '../router' import { Message } from 'element-ui'

Vue axios发送Http请求

axios 1.cnpm install axios --save 2.在vue文件中引入,import Axios from 'axios' 3.使用,Axios.get(url).then((res)=>{}).catch((err)=>{}) <template> <div id="app"> <div v-html="htmlValue"></div> </div> </templ

基于Promise封装uni-app的request方法,实现类似axios形式的请求

https://my.oschina.net/u/2428630/blog/3004860 uni-app框架中 安装(项目根目录下运行) npm install uni-request --save 文件中引用 import uniRequest from 'uni-request'; 使用方法 请求方法的别名 uniRequest.request(config) uniRequest.get(url[, config]) uniRequest.delete(url[, config]) un

vue项目配置 axios携带token请求头

在main.js中 import axios from 'axios' axios.defaults.baseURL = '' axios.interceptors.request.use(config => { //配置axios请求头,axios每次发起请求携带token,在Network中的headers看的到 // console.log(config) config.headers.Authorization = window.sessionStorage.getItem('token

vue-cli整合axios的几种方法

Vue这个框架现在在单页面应用方面非常受人欢迎. 基于vue-cli创建的项目怎么样才能更好地处理网络请求? 首选的应该就是axios了 这次给刚接触vue的新手介绍一下axios在vue中如何使用 安装的话自己去官网看 一.不推荐的方法 //在要使用网络请求的组件中导入axios import axios from 'axios' export default { name: 'HelloWorld', data () { return { params:{} } }, methods: {