关于vue- axios的post请求到后台数据为空的两种解决方法

 在vue里面的这种情况是默认使用get方式传值到后台,当你数据过大的时候,会导致你的拼接长度有限。

然后稍微改成这样:

这样就会使得与后台的交互方式为POST请求。但是出现了后台接到的值为空的现象。后面对比ajax发现axios传值,再具体观察控制台发现

 ajax方式:

 

一个Request Payload,一个Form Data。
将Request Payload 转为Form Data格式就可以了,有三种方式:

一、使用qs(推荐)

首先在你的项目里安装qs模块:

 

npm install qs --save-dev

然后在需要使用的页面引入一下:

 

import qs from 'qs'

引入好了之后,把上面的postData用qs转一下再发送给后台就可以了:

 

            var id = this.form.id;
        	var name = this.form.name;
        	var sex = this.form.sex;
        	var hobby = this.form.hobby;
        	var datetime = this.form.datetime;
        	var address = this.form.address;

let postData = qs.stringify({
            id:id,
            name:name,
            sex:sex,
            hobby:hobby,
            datetime:datetime,
            address:address
})

这样发送给后台时就是Format Data格式了。

二、使用URLSearchParams

 

            var postData= new URLSearchParams()
			var id = this.form.id;
        	var name = this.form.name;
        	var sex = this.form.sex;
        	var hobby = this.form.hobby;
        	var datetime = this.form.datetime;
        	var address = this.form.address;
        	postData.append('id',id)
        	postData.append('name',name)
        	postData.append('sex',sex)
        	postData.append('hobby',hobby)
        	postData.append('datetime',datetime)
        	postData.append('address',address)

这样也可以,个人觉得写起来麻烦。

两种种方法的原理是一样一样的,都是转化为字符串。个人推荐的是第一种方法。

  • 5
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Vue AxiosVue.js 应用程序中用于网络请求一个库,它封装了浏览器的 `XMLHttpRequest` 对象,提供了一套简洁、一致的 API 来处理 HTTP 请求。 当你使用 Vue Axios 的 `post` 方法发送 POST 请求后台,并接收到空响应(即服务器返回的数据一个空数组、对象或者是没有任何内容的状态码),这可能是由多种原因导致: ### 1. **服务端错误** - **未返回数据**:服务器可能仅返回了一个成功的状态码(如 HTTP 200 或 204 等),但实际上没有发送任何实际的数据内容。这通常意味着服务器处理请求正常完成,但在响应体中没有包含需要的内容。 - **配置问题**:后端代码可能存在错误,例如忘记从数据库获取数据或者返回了一个错误状态码而非期望的状态码。 ### 2. **客户端错误** - **Axios 配置错误**:可能是你在 Axios 中配置了错误的URL、headers或者其他设置,导致请求无法到达正确的API端点或按照预期工作。 - **Promise 处理不当**:在 Vue 中使用 Axios 发送请求后,你可能需要捕获和处理可能发生的错误。如果错误处理不当,可能会阻止你接收或显示来自服务器的实际数据。 ### 解决方案 #### 检查服务端代码 - 确保后端代码正确地从数据库查询数据并返回。检查是否有语法错误或逻辑错误,比如SQL注入、未捕获的异常等。 - 确认返回的HTTP状态码是否合理,通常应有相应的JSON响应体。 #### 检查 Axios 配置和使用 - **URL**: 确保在 Axios请求中指定了正确的API路径。 - **Headers**: 如果需要特定的头部信息(如身份验证令牌),确保它们正确添加到了请求中。 - **Promise 处理**: 使用 `.then()` 和 `.catch()` 正确处理响应结果和可能出现的错误。例如: ```javascript axios.post('your-api-url', yourData) .then(response => { // 处理成功情况,如更新组件状态 console.log(response.data); }) .catch(error => { // 错误处理,如显示错误消息给用户 console.error('Error fetching data:', error.message); }); ``` #### 日志和调试 - 在服务端增加日志记录,查看请求的具体情况,包括请求头、请求体以及响应状态码和内容,以便快速定位问题所在。 - 在前端同样可以使用类似 `console.log` 的函数来打印出关键变量的值,帮助诊断问题。 ### 相关问题: 1. **如何优化Axios的性能?** 提供一些最佳实践来提高请求效率和减少加载时间。 2. **如何处理更复杂的API交互?** 当涉及到登录、注册、分页、排序等功能时,如何更好地管理Axios的使用。 3. **遇到跨域问题时应该怎么做?** 解释在哪些情况下可能会出现问题,并提供解决方案。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值