axios传递参数的方式是什么
这篇文章主要讲解了“axios传递参数的方式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“axios传递参数的方式是什么”吧!
专注于为中小企业提供网站设计制作、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业惠阳免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
参数的传递方式
参数传递一般有两种,一种是 使用
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 一些关键代码如下 :
感谢各位的阅读,以上就是“axios传递参数的方式是什么”的内容了,经过本文的学习后,相信大家对axios传递参数的方式是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
网页标题:axios传递参数的方式是什么
网址分享:http://scyanting.com/article/ihicse.html