详解React Native网络请求fetch简单封装


Posted in Javascript onAugust 10, 2017

在原生应用开发中,为了方便业务开发人员使用,我们一般会对网络库进行一些上传封装,而不是直接使用,例如基于AFNetworking库的iOS请求上层封装,Android的诸如volley,retrofit等。在前端开发中,一般使用fetch进行网络请求,相关介绍请查看fetch示例。其实对于开发来说,系统提供的fetch已经够用了,但是为了代码的整体结构,建议对fetch进行简单的Get/Post封装。

若不封装,我们看一下传统的写法:

fetch('http://www.pintasty.cn/home/homedynamic', {
      method: 'POST',
      headers: { //header
        'token': 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VySWQiOiJVLTliZGJhNjBjMjZiMDQwZGJiMTMwYWRhYWVlN2FkYTg2IiwiZXhwaXJhdGlvblRpbWUiOjE0NzUxMTg4ODU4NTd9.ImbjXRFYDNYFPtK2_Q2jffb2rc5DhTZSZopHG_DAuNU'
      },
      body: JSON.stringify({ //参数
        'start': '0',
        'limit': '20',
        'isNeedCategory': true,
        'lastRefreshTime': '2016-09-25 09:45:12'
      })
    })
      .then((response) => response.json()) //把response转为json
      .then((responseData) => { // 上面的转好的json
          alert(responseData); /
        // console.log(responseData);
      })
      .catch((error)=> {
        alert('错误了');
      })
  }

是不是看着有一种密集恐惧症,并且代码的风格也不是很好。所以,为了方便使用,我们需要将公共的部分封装起来,然后只需要通过参数的方式对外暴露出诸如请求Url,请求参数,Header就可以了。

var HTTPUtil = {};

/**
 * GET请求
 */
HTTPUtil.get = function(url, params, headers) {
  if (params) {
    let paramsArray = [];
    //encodeURIComponent
    Object.keys(params).forEach(key => paramsArray.push(key + '=' + params[key]))
    if (url.search(/\?/) === -1) {
      url += '?' + paramsArray.join('&')
    } else {
      url += '&' + paramsArray.join('&')
    }
  }
  return new Promise(function (resolve, reject) {
   fetch(url, {
      method: 'GET',
      headers: headers,
     })
     .then((response) => {
       if (response.ok) {
         return response.json();
       } else {
         reject({status:response.status})
       }
     })
     .then((response) => {
       resolve(response);
     })
     .catch((err)=> {
      reject({status:-1});
     })
  })
}


/**
 * POST请求 FormData 表单数据
 */
HTTPUtil.post = function(url, formData, headers) {
  return new Promise(function (resolve, reject) {
   fetch(url, {
      method: 'POST',
      headers: headers,
      body:formData,
     })
     .then((response) => {
       if (response.ok) {
         return response.json();
       } else {
         reject({status:response.status})
       }
     })
     .then((response) => {
       resolve(response);
     })
     .catch((err)=> {
      reject({status:-1});
     })
  })
}

export default HTTPUtil;

还是上面的例子,我们怎么使用呢?

let formData = new FormData(); 
formData.append("id",1060); 
 let url='http://www.pintasty.cn/home/homedynamic';
  let headers='';
HTTPUtil.post(url,formData,headers).then((json) => { 
  //处理 请求结果 
  },(json)=>{ 
   //TODO 处理请求fail   
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用jQuery内容过滤选择器选择元素实例讲解
Apr 18 Javascript
js关闭浏览器窗口及检查浏览器关闭事件
Sep 03 Javascript
Javascript执行效率全面总结
Nov 04 Javascript
jquery datatable后台封装数据示例代码
Aug 07 Javascript
jQuery+easyui中的combobox实现下拉框特效
Feb 27 Javascript
js实现兼容IE和FF的上下层的移动
May 04 Javascript
Ionic实现仿通讯录点击滑动及$ionicscrolldelegate使用分析
Jan 18 Javascript
JS实现重新加载当前页面
Nov 29 Javascript
详解用vue编写弹出框组件
Jul 04 Javascript
详解如何解决Vue和vue-template-compiler版本之间的问题
Sep 17 Javascript
jQuery插件simplePagination的使用方法示例
Apr 28 jQuery
js 图片懒加载的实现
Oct 21 Javascript
jQuery Ajax 实现分页 kkpager插件实例代码
Aug 10 #jQuery
JS对象与JSON互转换、New Function()、 forEach()、DOM事件流等js开发基础小结
Aug 10 #Javascript
jquery.uploadView 实现图片预览上传功能
Aug 10 #jQuery
express框架实现基于Websocket建立的简易聊天室
Aug 10 #Javascript
bootstrap table服务端实现分页效果
Aug 10 #Javascript
AngularJs+Bootstrap实现漂亮的计算器
Aug 10 #Javascript
React-Native做一个文本输入框组件的实现代码
Aug 10 #Javascript
You might like
PHP关联链接常用代码
2012/11/05 PHP
php实现以只读方式打开文件的方法
2015/03/16 PHP
Yii使用migrate命令执行sql语句的方法
2016/03/15 PHP
PHP与Ajax相结合实现登录验证小Demo
2016/03/16 PHP
获取div编辑框,textarea,input text的光标位置 兼容IE,FF和Chrome的方法介绍
2012/11/08 Javascript
Javascript玩转继承(三)
2014/05/08 Javascript
js右下角弹出提示框示例代码
2016/01/12 Javascript
深入浅析JavaScript的API设计原则
2016/06/14 Javascript
nodejs模块学习之connect解析
2017/07/05 NodeJs
javascript将list转换成树状结构的实例
2017/09/08 Javascript
Vue监听事件实现计数点击依次增加的方法
2018/09/26 Javascript
微信小程序实现左滑动删除效果
2020/03/30 Javascript
微信小程序 this.triggerEvent()的具体使用
2019/12/10 Javascript
python中getaddrinfo()基本用法实例分析
2015/06/28 Python
Python中的字符串查找操作方法总结
2016/06/27 Python
python并发编程之多进程、多线程、异步和协程详解
2016/10/28 Python
Python中顺序表的实现简单代码分享
2018/01/09 Python
Python高级特性切片(Slice)操作详解
2018/09/27 Python
详解Django的CSRF认证实现
2018/10/09 Python
python实现最小二乘法线性拟合
2019/07/19 Python
python连接PostgreSQL数据库的过程详解
2019/09/18 Python
Python 实现3种回归模型(Linear Regression,Lasso,Ridge)的示例
2020/10/15 Python
UI自动化定位常用实现方法代码示例
2020/10/27 Python
使用canvas生成含有微信头像的邀请海报没有微信头像问题
2019/10/29 HTML / CSS
戴尔英国翻新电脑和电子产品:Dell UK Refurbished Computers
2019/07/30 全球购物
广告学专业应届生求职信
2013/10/01 职场文书
商务英语毕业生自荐信范文
2013/11/08 职场文书
残疾人创业典型事迹
2014/02/01 职场文书
就业意向书
2014/07/29 职场文书
2014年预备党员端正入党动机思想汇报
2014/09/13 职场文书
银行转正自我鉴定
2014/09/29 职场文书
公安交警中队队长个人对照检查材料思想汇报
2014/10/05 职场文书
嘉宾邀请函
2015/01/31 职场文书
旗帜观后感
2015/06/08 职场文书
Python 机器学习工具包SKlearn的安装与使用
2021/05/14 Python
python opencv通过按键采集图片源码
2021/05/20 Python