RN实战项目网络请求封装
RN中主要是用fetch来完成异步网络请求的,传统的ajax慢慢的会被fetch替代
RN中文网fetch API 案例http://www.jianshu.com/p/1cda2b889d47
fetch('https://mywebsite.com/endpoint/', {
method: 'POST', //请求方法 默认get
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json', //数据格式 json或者key-value形式
},
body: JSON.stringify({ //json对象转换为json字符串
firstParam: 'yourValue',
secondParam: 'yourOtherValue',
})
})
getMoviesFromApiAsync() {
return fetch('https://facebook.github.io/react-native/movies.json')
.then((response) => response.json())//回调结果,并转换为json对象 es6写法
.then((responseJson) => {
return responseJson.movies; //给调用者返回数据集合
})
.catch((error) => {
console.error(error); //网络请求出现错误,或者getMoviesFromApiAsync 函数调用者自身出现错误都会被这里catch住
});
}
项目中NetUtils封装
import React,{Component} from 'react';
import MD5 from "react-native-md5";
import {
ToastAndroid,
} from 'react-native';
export default class NetUtils extends Component{
constructor(props){
super(props);
}
static get(url,params,callback){
fetch(url,{
method:'GET',
body:params
})
.then((response) => {
if(response.ok){
return response.json();
}
})
.then((json) => {
if(json.resultCode === "SUCCESS"){
callback(json);
}else{
ToastAndroid.show(json.resultDesc,ToastAndroid.SHORT);
}
}).catch(error => {
ToastAndroid.show("netword error",ToastAndroid.SHORT);
});
};
static post(url,service,params,callback){
var newParams = this.getNewParams(service,params);
fetch(url,{
method:'POST',
headers:{
'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'
},
body:newParams
})
.then((response) => {
if(response.ok){
return response.json();
}
})
.then((json) => {
if(json.resultCode === "SUCCESS"){
callback(json);
}else{
ToastAndroid.show(json.resultDesc,ToastAndroid.SHORT);
}
}).catch(error => {
alert(error);
});
};
static postJson(url,service,jsonObj,callback){
fetch(url,{
method:'POST',
headers:{
'Content-Type': 'application/json;charset=UTF-8'
},
body:JSON.stringify(jsonObj),
})
.then((response) => {
if(response.ok){
return response.json();
}
})
.then((json) => {
if(json.resultCode === "SUCCESS"){
callback(json);
}else{
ToastAndroid.show(json.resultDesc,ToastAndroid.SHORT);
}
}).catch(error => {
ToastAndroid.show("netword error",ToastAndroid.SHORT);
});
};
static getCurrentDate(){
var space = "";
var dates = new Date();
var years = dates.getFullYear();
var months = dates.getMonth()+1;
if(months<10){
months = "0"+months;
}
var days = dates.getDate();
if(days<10){
days = "0"+days;
}
var hours = dates.getHours();
if(hours<10){
hours = "0"+hours;
}
var mins =dates.getMinutes();
if(mins<10){
mins = "0"+mins;
}
var secs = dates.getSeconds();
if(secs<10){
secs = "0"+secs;
}
var time = years+space+months+space+days+space+hours+space+mins+space+secs;
return time;
};
static getNewParams(service,oldParams){
var newParams = "";
var currentDate = this.getCurrentDate();
var MD5KEY = "XXXXXX";
var digestStr = MD5KEY+service+currentDate+MD5KEY;
newParams = oldParams+"×tamp="+currentDate+"&digest="+this.MD5(digestStr);
return newParams;
};
static MD5(str){
return MD5.hex_md5(str);
};
static getCurrentDateFormat(){
var space = "";
var dates = new Date();
var years = dates.getFullYear();
var months = dates.getMonth()+1;
if(months<10){
months = "0"+months;
}
var days = dates.getDate();
if(days<10){
days = "0"+days;
}
var time = years+space+months+space+days;
return time;
};
}
测试并使用
import NetUtils from '../net/NetUtils';
export default class Index extends Component {
constructor(props) {
super(props);
}
componentDidMount() {
var url = 'http:
var service = "clerkDetail";
var userInfo;
AsyncStorage.getItem("userInfo", (error, result) => {
if (error) {
} else {
userInfo = eval('(' + result + ')');
var params = "service=clerkDetail&pageSize=10&page=1&userId=" + userInfo.userId;
NetUtils.post(url, service, params, (result) => {
ToastAndroid.show(result.resultDesc, ToastAndroid.SHORT);
});
}
});
};
}
}
由于NetUtils是一个外部的js文件,所以在使用的地方一定要记得import NetUtils from '../net/NetUtils';
这里遇到的坑:
一:import 的时候 NetUtils.js 后面的.js可以去掉,路径填写相对路径
二:NetUtils.js里面 export default class NetUtils extends Component{} 组件必须export default 声明,切记一个js文件中只能有且仅有一个default声明
三:get post postJson方法都用了static 声明,直接NetUtils.post/get/postJosn即可