React Native 使用Fetch发送网络请求的示例代码

我们在项目中经常会用到HTTP请求来访问网络,HTTP(HTTPS)请求通常分为"GET"、"PUT"、"POST"、"DELETE",如果不指定认为GET请求。

在项目中我们常用到的一般为GET和POST两种请求方式,针对带参数的表单提交这类的请求,我们通常会使用POST的请求方式。

为了发出HTTP请求,我们需要使用到 React Native 提供的 Fetch API 来进行实现。要从任意地址获取内容的话,只需简单地将网址作为参数传递给fetch方法即可(fetch这个词本身也就是获取的意思

GET

如果你想要通过 GET 方法去请求数据并转化成 JSON,可以通过如下代码实现:

response.json()) .then((responseJson) => { return responseJson.movies; }) .catch((error) => { console.error(error); });

通过上面的请求把返回的 Response 转化成 JSON Object,然后取出 JSON Object 里的 movies 字段。同时,如果发生 Error,如网络不通或访问连接错误等, 会被 .catch 。在正常的情况下,我们可以得到如下结果:

rush:js;"> { "title": "The Basics - Networking","description": "Your app fetched this from a remote endpoint!","movies": [ { "title": "Star Wars","releaseYear": "1977"},{ "title": "Back to the Future","releaseYear": "1985"},{ "title": "The Matrix","releaseYear": "1999"},{ "title": "Inception","releaseYear": "2010"},{ "title": "Interstellar","releaseYear": "2014"} ] }

POST(一)

当然,上面是最基本的 GET 请求,Fetch还有可选的第二个参数,可以用来定制HTTP请求一些参数。你可以指定Headers参数,或是指定使用POST方法,又或是提交数据等等:Fetch API 还支持自定义 Headers,更换 Method,添加 Body 等。

rush:js;"> let url = "http://www.yousite.com/xxxx.ashx” let params = {"name":"admin","password":"admin"}; fetch(url,{ method: 'POST',headers: { 'Accept': 'application/json','Content-Type': 'application/json',},body: JSON.stringify(params) })

上面构建了一个基本的 POST 请求,添加了自己的 Headers:Accept和Content-Type,添加了 Body。

POST(二)

{ if (response.ok) { return response.json(); } }).then((json) => { console.log(json) }).catch((error) => { console.error(error); });

POST(三)推荐

通过上面两种方法,我们还有一种方式可以发送POST请求,当然这种方式也是被推荐使用的。

如果你的服务器无法识别上面POST的数据格式,那么可以尝试传统的form格式,示例如下:

// 首先我们需要自己创建一个FormData,来存请求参数

let parameters = new FormData();
parameters.append("mt","30013");
parameters.append("pg","1");
parameters.append('ps','20');

fetch(REQUEST_URL,body: parameters
}).then(
(result) => {
if (result.ok) {
console.log(result)
result.json().then(
(obj) => {
console.log(obj)
}
)
}
}
).catch((error) => {
console.log(error)
Alert.alert('Error')
})

推荐这种方法的好处还有一个,就是可以在FormData中直接传递字节流实现上传图片功能代码如下:

formData.append("images",file);

fetch(url,{
method:'POST',headers:{
'Content-Type':'multipart/form-data',body:formData,})
.then((response) => response.text() )
.then((responseData)=>{

console.log('responseData',responseData);
})
.catch((error)=>{console.error('error',error)});

}

处理服务器的响应数据

上面的例子演示了如何发起请求。很多情况下,你还需要处理服务器回复的数据。 网络请求天然是一种异步操作,Fetch 方法会返回一个Promise,这种模式可以简化异步风格的代码,关于Promise,请参考:Promise

处理服务器返回的数据,我们已经在上面第二种和第三种的POST请求中实现了数据的处理。具体代码参考上面的实现代码

认情况下,iOS会阻止所有非https的请求。如果你请求的接口是http协议,那么首先需要添加一个App Transport Security的例外。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...