详解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 相关文章推荐
js判断生效时间不得大于失效时间的思路及代码
Apr 23 Javascript
window.open打开页面居中显示的示例代码
Dec 27 Javascript
js实现遮罩层弹出框的方法
Jan 15 Javascript
javascript基本语法
May 31 Javascript
AnjularJS中$scope和$rootScope的区别小结
Sep 18 Javascript
详解JavaScript时间处理之几个月前或几个月后的指定日期
Dec 21 Javascript
js/jq仿window文件夹移动/剪切/复制等操作代码
Mar 08 Javascript
使用Electron构建React+Webpack桌面应用的方法
Dec 15 Javascript
layui获取多选框中的值方法
Aug 15 Javascript
JavaScript实现抖音罗盘时钟
Oct 11 Javascript
基于jQuery实现可编辑的表格
Dec 11 jQuery
vue 使用class创建和清除水印的示例代码
Dec 25 Vue.js
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/09/06 PHP
日常整理PHP中简单的图形处理(经典)
2015/10/26 PHP
thinkPHP5.0框架命名空间详解
2017/03/18 PHP
js函数setTimeout延迟执行的简单介绍
2013/07/17 Javascript
javascript 用函数语句和表达式定义函数的区别详解
2014/01/06 Javascript
基于javascript实现泡泡大冒险网页版小游戏
2016/03/23 Javascript
JavaScript通过HTML的class来获取HTML元素的方法总结
2016/05/24 Javascript
一个简单的JavaScript Map实例(分享)
2016/08/03 Javascript
基于jQuery的select下拉框选择触发事件实例分析
2016/11/18 Javascript
深入理解Angularjs向指令传递数据双向绑定机制
2016/12/31 Javascript
基于jQuery封装的分页组件
2017/06/26 jQuery
JS实现闭包中的沙箱模式示例
2017/09/07 Javascript
使用Bootstrap和Vue实现用户信息的编辑删除功能
2017/10/25 Javascript
使用DataTable插件实现异步加载数据
2017/11/19 Javascript
浅谈webpack打包过程中因为图片的路径导致的问题
2018/02/21 Javascript
浅谈vue项目可以从哪些方面进行优化
2018/05/05 Javascript
vue vue-Router默认hash模式修改为history需要做的修改详解
2018/09/13 Javascript
js使用formData实现批量上传
2020/03/27 Javascript
基于nodejs的微信JS-SDK简单应用实现
2019/05/21 NodeJs
基于JS抓取某高校附近共享单车位置 使用web方式展示位置变化代码实例
2019/08/27 Javascript
vue Element左侧无限级菜单实现
2020/06/10 Javascript
Vue实现腾讯云点播视频上传功能的实现代码
2020/08/17 Javascript
javascript实现随机抽奖功能
2020/12/30 Javascript
Vue实现todo应用的示例
2021/02/20 Vue.js
Python中生成Epoch的方法
2017/04/26 Python
Tensorflow 自带可视化Tensorboard使用方法(附项目代码)
2018/02/10 Python
Django 视图层(view)的使用
2018/11/09 Python
python如何实现视频转代码视频
2019/06/17 Python
简单了解Django ContentType内置组件
2019/07/23 Python
python3:excel操作之读取数据并返回字典 + 写入的案例
2020/09/01 Python
python利用线程实现多任务
2020/09/18 Python
python实现代码审查自动回复消息
2021/02/01 Python
纯HTML5+CSS3制作生日蛋糕(代码易懂)
2016/11/16 HTML / CSS
公司JAVA开发面试题
2015/04/02 面试题
交通事故委托书范本精选
2014/10/04 职场文书
民政局未婚证明
2015/06/15 职场文书