axios 传递参数的方式(data 与 params 的区别)

简介: axios 大家都非常的清楚,一个既可以用于客户端或者 服务端发送http请求的库。但是在前后端联调的时候有的时候会很难受,所以这里我来做一个总结。希望能帮助到有缘人。

axios 大家都非常的清楚,一个既可以用于客户端或者 服务端发送http请求的库。但是在前后端联调的时候有的时候会很难受,所以这里我来做一个总结。希望能帮助到有缘人。


参数的传递方式


参数传递一般有两种,一种是 使用 params, 另一种是 data的方式,有很多的时候我们看到的前端代码是这样的。


get 请求


axios({
    method: 'GET',
    url: 'xxxxx',
    params: param,
  })
或者 
axios({
    method: 'GET',
    url: '/xxx?message=' + msg,
  })


post 请求


axios({
    method: 'POST',
    url: '/xxxxx',
    data: param,
  })
  或者
 axios({
    method: 'POST',
    url: '/xxxxx',
    params: param,
  })


正确传递


传递参数的解决办法分为post和get,咋们从这里来看一下


post


post 是大多数人会搞错的,咋们来看看。


data 的形式


从例子中说话,使用的案例代码是post参数,并且没有做任何的转码。


b3b2084e3e71fcf867ffb63a98794031.png

 method: 'POST',
    url: '/xxxxx',
    data: param,
  })


控制台结果


e19cbf63ca0397ec9701b825508ed7c6.png


使用data传递的是一个对象,在控制台中看到的话是 request payload


参数的view sources如下:


2538ae8ec96e8d717315b9230e9da35c.png


node 后台接收参数的方式


这里我采用的是koa 来搭建的后台。需要使用 koa-bodyparser 这个插件来解析body 的参数


import Koa from 'koa';
import bodyParser from 'koa-bodyparser'
const app = new Koa();
// 解析body
app.use(bodyParser());
app.listen(9020, () => {
  console.log('the server is listen 9020 port');
})


接受方式如下:


1af37f958fa6c990cb7b62443ef2cce0.png


java 后台接收参数的方式


对于 java 来说,本人并不是那么熟悉,但是知道的是。如果需要接受axios 以data 传递的参数。需要使用注解 @responseBody 并且使用的是实体类来接收的.


a76ee1cce72db7cd9768367514caf649.png


post data 的形式 ,不管是 哪种服务端的语言,都需要从body中获取参数。主要用于 传递 对象的参数,后台拿到的数据是一个 obj。 data 形式的数据有可以做好多事情, 文件上传,表单提交 等


params 的形式


这个是一个对象形式传递的,案例代码如下:


d69fce38d94364ce19b72add82e4f10b.png

 axios({
    method: 'POST',
    url: '/xxxxx',
    params: param,
  })


浏览器结果分析


b609120026e480cecbe32e385d5daa75.png


查看view sourcer 如下:


f013a1ff6c14c55304d1e8a2cd6b3401.png


node 后台接收参数的方式


启动服务和上面一样,但是接收参数的方式有点变化


fcaf0d2f26cf708cd812b66aa4cc85d2.png


java 后台接收参数的方式


这个本人搞不来 ,理论上是从地址栏上获取参数。应该也是 使用某个注解吧


get 请求


get 请求不管使用哪种方式,最后的参数都会放到路径上。


使用param 只是axios帮你把这个参数进行了序列化,并且拼接在 url上面。原因的话,请查看下面


出现两种的原因


遇到这个问题,咋们就需要去看 axios 的源码了.这里 只会看处理参数的部分。有兴趣的自己去查看源码。


处理data


在axios文件中 的 core/dispatchRequest.js 中,我们可以看到 ,axois会 data


4b14de6cf5ae6ffc601a703303603d8d.png


在 axios 的 default.js 中,有一个函数专门转换 data 参数的 。


96043d3c2577e97bef91232299829f27.png


注意: 上面只是举例 data 传递参数的一种情况哈!其实data 也有在地址栏 上 拼接的情况,或者 是文件上传的等情况。太多了,这里 只是讲清楚使用的方式。


处理 params


在axios文件中 的 adapt/ xhr.js 中,我们可以看到 ,axois会 params的参数放到url路径中。


e2c0e9431f0a7d16e52a298d8c9573f9.png


buildUrl 一些关键代码如下 :


a9d8c7da580444c31595189faa6b0072.png


总结


其实前端和后端 对接参数过程,对于post请求,data 不行,那就使用 params来 进行 传递,如果都不行,那就可能后端有问题了。


彩蛋


后台测试数据可以使用 postman, 如果可以传递的参数可以调用通过。postman是可以看到请求的代码的方式的。


349cf9ff3875bd6e5c6a59f8e438564a.png


相关文章
|
8月前
|
负载均衡 前端开发 搜索推荐
Axios 和 Ajax 的区别
Axios 和 Ajax 的区别
|
3月前
|
XML 前端开发 JavaScript
详解Ajax与axios的区别
详解Ajax与axios的区别
|
7月前
|
JSON 前端开发 JavaScript
前端Ajax、Axios和Fetch的用法和区别笔记
前端Ajax、Axios和Fetch的用法和区别笔记
142 2
|
8月前
|
前端开发 JavaScript API
axios和ajax的区别
axios和ajax的区别
111 0
|
JSON 前端开发 JavaScript
ajax和axios、fetch的区别
ajax和axios、fetch的区别
|
XML 存储 JSON
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(上)
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(上)
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(上)
|
XML 存储 JSON
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(下)
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(下)
|
存储 JSON 缓存
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(中)
【JavaScript】爆肝 2 万字!一次性搞懂 Ajax、Fetch 和 Axios 的区别~(中)
axios ‘get’与‘post’的区别
axios ‘get’与‘post’的区别
299 0
|
JavaScript 安全
vue总结之axios(post请求和get请求的区别)
vue总结之axios(post请求和get请求的区别)

热门文章

最新文章

  • 1
    JavaScript 使用axios库发送 post请求给后端, 给定base64格式的字符串数据和一些其他参数, 使用表单方式提交, 并使用onUploadProgress显示进度
    532
  • 2
    若依修改,若依如何发送请求---王清江07,axios的请求在request.js文件中,若依发送GET请求,必须用param
    227
  • 3
    axios发送post请求,如何接受和返回一个axios的字段,解决bug的方法,困难的事情先从简单做起,先从发送一个axios的post请求做起,解决方法查别人的资料,查看F12看network就行
    52
  • 4
    文本,前后端数据交互,简单请求,如何去给data数据赋值,在mounted()里赋值,利用axios发送的请求,res就是数据集,就是后端的数据,this.users = res.data.data
    52
  • 5
    Request failed with status code 400,使用axios.post要发送参数,认真比对原项目,看看有没有忘记什么?
    122
  • 6
    vue3 在 watchEffect 里中断未完成的 axios 请求(只保留最后一次请求的方法---连续点击查询按钮的优化)
    152
  • 7
    前后端数据交互.js文件的axios的写法,想要往后端发送数据,页面注入API,await的意思是同步等待服务器数据,并返回,axios注入在其他页面,其他页面调用的时候,同步作用
    60
  • 8
    前后端数据交互,API风格组合式API和选项式API,setup是一个标识,组合式编写的意思,使定义count.value的值自增的写法,组合式API使用axios的写法,ref定义响应数据写法
    38
  • 9
    网页设计,若依项目修改(It must be done)02------axios封装后发get请求,axios请求的位置在呢?
    54
  • 10
    前后端数据交互之axios的路径怎样找?axios的路径是那个,是你打开Tomcat之后,出现的路径+你项目写的接口路径
    52