《React-Native系列》32、 基于Fetch封装HTTPUtil工具类

本文主要是介绍《React-Native系列》32、 基于Fetch封装HTTPUtil工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于http请求的工具类,有很多,譬如:httpclient,okhttp。

那么关于RN的处理HTTP请求的工具类呢,目前还没有找到,所以自己简单封装了一个,避免代码里到处都是fetch方法。

好了,完整代码如下:

[javascript]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. var HTTPUtil = {};  
  2.   
  3. /** 
  4.  * 基于 fetch 封装的 GET请求 
  5.  * @param url 
  6.  * @param params {} 
  7.  * @param headers 
  8.  * @returns {Promise} 
  9.  */  
  10. HTTPUtil.get = function(url, params, headers) {  
  11.     if (params) {  
  12.         let paramsArray = [];  
  13.         //encodeURIComponent  
  14.         Object.keys(params).forEach(key => paramsArray.push(key + '=' + params[key]))  
  15.         if (url.search(/\?/) === -1) {  
  16.             url += '?' + paramsArray.join('&')  
  17.         } else {  
  18.             url += '&' + paramsArray.join('&')  
  19.         }  
  20.     }  
  21.     return new Promise(function (resolve, reject) {  
  22.       fetch(url, {  
  23.             method: 'GET',  
  24.             headers: headers,  
  25.           })  
  26.           .then((response) => {  
  27.               if (response.ok) {  
  28.                   return response.json();  
  29.               } else {  
  30.                   reject({status:response.status})  
  31.               }  
  32.           })  
  33.           .then((response) => {  
  34.               resolve(response);  
  35.           })  
  36.           .catch((err)=> {  
  37.             reject({status:-1});  
  38.           })  
  39.     })  
  40. }  
  41.   
  42.   
  43. /** 
  44.  * 基于 fetch 封装的 POST请求  FormData 表单数据 
  45.  * @param url 
  46.  * @param formData   
  47.  * @param headers 
  48.  * @returns {Promise} 
  49.  */  
  50. HTTPUtil.post = function(url, formData, headers) {  
  51.     return new Promise(function (resolve, reject) {  
  52.       fetch(url, {  
  53.             method: 'POST',  
  54.             headers: headers,  
  55.             body:formData,  
  56.           })  
  57.           .then((response) => {  
  58.               if (response.ok) {  
  59.                   return response.json();  
  60.               } else {  
  61.                   reject({status:response.status})  
  62.               }  
  63.           })  
  64.           .then((response) => {  
  65.               resolve(response);  
  66.           })  
  67.           .catch((err)=> {  
  68.             reject({status:-1});  
  69.           })  
  70.     })  
  71. }  
  72.   
  73. export default HTTPUtil;  

怎么使用呢,举个简单的例子吧:

[javascript]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. let formData = new FormData();  
  2. formData.append("id",1060);  
  3.         
  4. HTTPUtil.post(url,formData,headers).then((json) => {  
  5.     //处理 请求success  
  6.     if(json.code === 0 ){  
  7.             //我们假设业务定义code为0时,数据正常  
  8.         }else{  
  9.              //处理自定义异常  
  10.             this.doException(json);  
  11.         }  
  12.    },(json)=>{  
  13.      //TODO 处理请求fail  
  14.         
  15. })  

这篇关于《React-Native系列》32、 基于Fetch封装HTTPUtil工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510330

相关文章

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Java中的工具类命名方法

《Java中的工具类命名方法》:本文主要介绍Java中的工具类究竟如何命名,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java中的工具类究竟如何命名?先来几个例子几种命名方式的比较到底如何命名 ?总结Java中的工具类究竟如何命名?先来几个例子JD

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加