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

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参数,并且没有做任何的转码。 

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

 控制台结果

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

node 后台接收参数的方式 

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

import Koa from 'koa';
import bodyParser from 'koa-bodyparser'
const app = new Koa();


app.use(bodyParser());

app.listen(9020, () => {
  console.log('the server is listen 9020 port');
})

接受方式如下:

java 后台接收参数的方式

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

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

params 的形式

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

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

浏览器结果分析

查看view sourcer 如下:

node 后台接收参数的方式

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

java 后台接收参数的方式

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

get 请求

get 请求不管使用哪种方式,最后的参数都会放到路径上。 使用param 只是axios帮你把这个参数进行了序列化,并且拼接在 url上面。原因的话,请查看下面

出现两种的原因

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

处理data

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

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

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

处理 params

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

buildUrl 一些关键代码如下 :

总结

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

  • 12
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: axios请求参数中的dataparams是两种不同的参数。其中data用于POST、PUT、PATCH等需要传输数据体的请求方法,params则用于GET、DELETE等不需要传输数据体的请求方法。data是一个对象,包含需要传输的数据信息,而params则是一个键值对,用于传递URL查询字符串参数。 ### 回答2: axios是一款基于Promise的轻量级HTTP客户端,用于发送HTTP请求,支持现代浏览器和Node.js环境中使用。 axios请求参数主要包括dataparams。两者的区别在于传递方式不同。 data用于发送POST请求时携带的数据,数据以键值对(key-value)的形式传递,后端可在请求体中获取数据并进行处理。一般情况下,data传递参数对象、FormData对象以及Blob对象。其中,FormData对象可用于上传文件,Blob对象可用于上传二进制数据。 params用于发送GET请求时的查询参数,数据以键值对(key-value)的形式传递。在发送GET请求时,参数可以作为查询字符串的一部分,如: ``` axios.get('/api/users', { params: { firstName: 'John', lastName: 'Doe', age: 25 } }) ``` 这将向/api/users请求发送一个GET请求,查询参数为?firstName=John&lastName=Doe&age=25。后端可在请求的query中获取查询参数并进行处理。 总体来说,dataparams的作用有些类似,都是用于传递数据,但两者的使用场景和传递方式不同。正确的使用方式能够使代码结构更加健壮可靠。 ### 回答3: axios是一个流行的JavaScript库,用于在浏览器和Node.js中进行HTTP请求。它提供了两个参数用于发送请求:dataparams。这两个参数都是用于请求数据的,但有着不同的用途。 1. data data参数用于在请求体中添加数据。当我们使用POST、PUT和PATCH方法时,我们需要在请求体中向服务器发送数据。这些数据可以是一个JavaScript对象、Buffer、FormData、ArrayBuffer等类型的数据。 例如: ``` axios.post('/api/users', { name: 'John', age: 30 }) .then(response => console.log(response.data)) .catch(error => console.log(error)); ``` 在这个例子中,我们向服务器发送一个POST请求,请求URL为'/api/users',并且我们通过data参数发送了一个包含'name'和'age'键值对的JavaScript对象。服务器可以从请求体中获取到这些数据。 2. params params参数用于向URL中添加查询参数。当我们使用GET请求时,我们需要在URL中添加查询参数,发送数据给服务器。这些参数是包含键值对的对象,键是查询参数名,值是查询参数值。 例如: ``` axios.get('/api/users', { params: { name: 'John', age: 30 } }) .then(response => console.log(response.data)) .catch(error => console.log(error)); ``` 在这个例子中,我们向服务器发送一个GET请求,请求URL为'/api/users',并且我们通过params参数发送了一个包含'name'和'age'键值对的JavaScript对象。这将把查询参数添加到URL中,最终URL将是'/api/users?name=John&age=30'。服务器可以从查询参数中获取数据。 总结一下,axios的'data'参数用于POST、PUT和PATCH请求,用于向请求体中添加数据,而'params'参数用于GET请求,用于向URL中添加查询参数。正确使用这两个参数可以帮助我们更好地与服务器进行通信,并获取我们所需的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值