您现在的位置是:群英 > 开发技术 > web开发
axios传递参数有几种方式,前后端怎样联调
Admin发表于 2022-11-19 17:51:071051 次浏览
这篇文章给大家介绍了“axios传递参数有几种方式,前后端怎样联调”的相关知识,讲解详细,步骤过程清晰,对大家进一步学习和理解“axios传递参数有几种方式,前后端怎样联调”有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。

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 来说,本人并不是那么熟悉,但是知道的是。如果需要接受axiosdata 传递的参数。需要使用注解 @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 中,我们可以看到 ,axoisdata

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

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

处理 params

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

buildUrl 一些关键代码如下 :

总结

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


通过以上内容的阐述,相信大家对“axios传递参数有几种方式,前后端怎样联调”已经有了进一步的了解,更多相关的问题,欢迎关注群英网络或到群英官网咨询客服。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: axios传递参数
相关信息推荐
2022-06-01 17:34:04 
摘要:php是服务器端的。php是一种运行在服务器端的嵌入式脚本语言,主要用来响应用户的请求,可以处理用户通过网页提交的信息;PHP语言创建的主要目标是让开发人员快速编写出优质的web网站,在WEB服务领域占比率较高,但也可用于命令行脚本等领域。
2022-05-18 17:39:26 
摘要:本文实例为大家分享了js实现图片验证码功能的具体代码,供大家参考,具体内容如下以下代码可以直接copy运行,不需要引入jquery.jar1. html代码<%@ page language="
2021-11-17 18:05:40 
摘要:这篇文章给大家分享的是PHP pthreads v3的使用。下文介绍了一些pthreads v3使用中需要注意的问题,小编觉得挺实用的,对大家学习pthreads v3使用有一定的帮助,因此分享给大家做个参考,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部