React项目中Fetch无法向后端传递参数

问题:React项目中使用fetch向后端传递数据,POST请求时,发现把参数装进一个对象传递,后端并不能获取到数据,拼接成字符串加在URL中传递也不行(当然,GET请求可以)

解决:使用FormData传递参数

let formData = new FormData();

formData.append('name', 'kong');

formData.append('age', '18');

fetch(url, {method: 'POST', body: formData})...

例子:封装的一个请求Fetch的类

import Config from './config.js';

class Fetch extends Config{
	
	constructor(url, params, successFunc, errorFunc){
		super();
		this.url = super()._URL + url;
		this.params = params;
		this.successFunc = successFunc;
		this.errorFunc = errorFunc;
	}

	//发送GET请求
	getFetch(){
		var that = this;
		var str = '';
		if(typeof that.params === 'object' && that.params){
			str += '?';
			Object.keys(that.params).forEach(function(val){
				str += val + '=' + encodeURIComponent(that.params[val]) + '&';
			})
		}
		fetch(this.url + str, {
			method : 'GET'
		}).then(function(res){
			if(res.ok){
				res.json().then(function(data){
					that.successFunc(data);
				})
			}else if(res.status === 401){
				console.log('请求失败');
				that.errorFunc();
			}
		}, function(e){
			console.log('请求失败');
			that.errorFunc();
		})
	}
	
	//发送POST请求
	postFetch(){
		var that = this;
		var formData = new FormData();
		for(let k in that.params){
			formData.append(k, that.params[k]);
		}
		formData.append('oper_id', '11');
		formData.append('oper_name', 'kong');
		fetch(this.url, {
			method : 'POST',
			mode : 'cors',
			body : formData
		}).then(function(res){
			if(res.ok){
				res.json().then(function(data){
					that.successFunc(data);
				})
			}else{
				console.log('请求失败');
				that.errorFunc();
			}
		}, function(e){
			console.log('请求失败');
			that.errorFunc();
		})
	}
}

export default Fetch;
参考链接:

http://blog.csdn.net/yueaini10000/article/details/52597661

https://github.com/github/fetch

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React项目的职责主要包括以下几个方面: 1. UI组件开发:React是一个用于构建用户界面的JavaScript库,项目的开发人员使用React来创建可重用的UI组件。这些组件可以包括按钮、表单、导航栏等等,用于构建整个应用的用户界面。 2. 状态管理:React项目通常使用状态管理库(如Redux、Mobx等)来管理应用的状态。开发人员需要定义和维护应用的状态,并确保状态的一致性和可追踪性。 3. 路由管理:对于较大规模的React项目,通常需要使用路由库(如React Router)来管理不同页面之间的导航和路由。开发人员需要配置和维护应用的路由规则,并确保页面之间的跳转和参数传递正常工作。 4. 数据请求和处理:React项目通常需要与后端API进行数据交互,开发人员需要使用适当的工具(如axios、fetch等)发送HTTP请求,并处理返回的数据。这包括数据的获取、展示和更新等操作。 5. 性能优化:React项目,性能优化是一个重要的职责。开发人员需要注意组件的渲染性能,避免不必要的渲染和重复计算。他们还可以使用React提供的性能工具(如React Profiler)来分析和优化应用的性能。 6. 测试和调试:开发人员需要编写单元测试和集成测试来确保React组件的正确性和稳定性。他们还需要使用浏览器开发工具(如Chrome DevTools)来调试和排查应用的问题。 7. 项目构建和部署:React项目通常需要使用构建工具(如Webpack、Parcel等)将源代码打包成可部署的静态文件。开发人员需要配置构建工具,并将打包后的文件部署到服务器或云平台上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值