鸿蒙NEXT实战开发: 依据前端对http哀求举行二次简单封装 ...

打印 上一主题 下一主题

主题 983|帖子 983|积分 2949

 一、为什么要对http哀求举行封装?

在我看来二次封装有一下几点好处


  • 代码封装之后,开发人员只用关注业务层面的东西,不用去过多浪费时间在接口哀求数据处理上。
  • 封装之子女码更加简洁,普通易懂,方便后期维护,统一管理。
  • 对履历不足的开发人员友爱,只须要依葫芦画瓢,参照之前的例子就可以举行开发。
  • 随着团队规模变大,代码封装之后,减少代码冗余,防止屎山代码。
  • 统一处理token修改设置项,统一对数据错误和数据返回举行处理提示等。
二、注意事项



  • 使用HTTP数据哀求须要申请ohos.permission.INTERNET权限权,限申请请参考访问控制(权限)开发指导。
  • 此次封装功能并没有像axios 内里一样有响应拦截器和哀求拦截前。
  • 没有取消重复哀求、错误哀求重连的功能,所以只得当较小的项目。
三、开始举行封装

1. 创建哀求实体类

在ets/common/utils下创建文件request.ets
  1. import http from '@ohos.net.http';
  2. export  interface  httpConfig{
  3.   url:string;
  4.   method:http.RequestMethod;
  5.   timeOut?: number;
  6.   data?: string | Object | ArrayBuffer;
  7.   header?: Object;
  8.   expectDataType?: http.HttpDataType;
  9. }
  10. interface HttpResponse{
  11.    code:string|number;
  12.    message:string;
  13.    data:string|Object|unknown[]
  14. }
  15. export default  (config: httpConfig): Promise<HttpResponse>=> {
  16.   // 创建请求实例
  17.   const service = http.createHttp();
  18. }
复制代码
2. 对哀求实体类举行 Promise 封装

这内里参加了Authorization 身份信息、 Content-Type响应方式、connectTimeout毗连超时等 自己须要根据实际业务环境更换
  1. import http from '@ohos.net.http';
  2. export  interface  httpConfig{
  3.   url:string;
  4.   method:http.RequestMethod;
  5.   timeOut?: number;
  6.   data?: string | Object | ArrayBuffer;
  7.   header?: Object;
  8.   expectDataType?: http.HttpDataType;
  9. }
  10. interface HttpResponse{
  11.    code:string|number;
  12.    message:string;
  13.    data:string|Object|unknown[]
  14. }
  15. export default  (config: httpConfig): Promise<HttpResponse>=> {
  16.   // 创建请求实例
  17.   const service = http.createHttp();
  18.   //请求地址
  19.   const url ='http://XXX.XXX' +config.url;
  20.   return new Promise((resolve, reject) => {
  21.     service.request(
  22.       url,
  23.       {
  24.         method: config.method,
  25.         expectDataType: config.expectDataType, //数据类型
  26.         header: {
  27.           "Content-Type":"application/json",
  28.           //header中存放身份信息
  29.           Authorization:"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9",
  30.           ...config.header,
  31.         },
  32.         extraData: config.data,
  33.         readTimeout:config.timeOut|| 50000,
  34.         connectTimeout:config.timeOut|| 50000
  35.       },
  36.       (err, response)=>{
  37.         if (!err && response.responseCode === 200) { //请求200
  38.           if (typeof response.result === 'string') {
  39.             const resData=  JSON.parse(response.result)
  40.             if(resData.code==2001){ //接口状态成功
  41.               resolve(resData)
  42.             }else{
  43.               // 接口约定好的状态码 例如登录过期 等等
  44.               reject(response)
  45.             }
  46.           } else {
  47.             //接口返回数据异常
  48.             reject(response)
  49.           }
  50.         } else {
  51.           // 状态码异常 例如 404 502 503 等等
  52.           // 请求失败通常是后端问题或者网络问题
  53.           reject(response)
  54.         }
  55.        }
  56.     )
  57.   })
  58. }
复制代码
3. 封装一个公共提示框


                                     

在 ets/common/utils 下创建文件DialogUtils.ets 内容如下
  1. /**
  2. * This is a pop-up window tool class, which is used to encapsulate dialog code.
  3. * Developers can directly invoke the methods in.
  4. */
  5. export class DialogUtils {
  6.   /**
  7.    * 轻提示
  8.    */
  9.   toast(content:{message:string}) {
  10.     AlertDialog.show({
  11.       message: content.message,
  12.       alignment: DialogAlignment.Center,
  13.       primaryButton: {
  14.         value: '取消',
  15.         action: () => {
  16.         }
  17.       },
  18.       secondaryButton: {
  19.         value: '确认',
  20.         action: () => {
  21.         }
  22.       }
  23.     });
  24.   }
  25. }
  26. export default new DialogUtils();
复制代码
4. 在哀求内里多错误状态举行相应判断处理提示

  1. import http from '@ohos.net.http';
  2. import  DialogUtils from "./DialogUtils"
  3. export  interface  httpConfig{
  4.   url:string;
  5.   method:http.RequestMethod;
  6.   timeOut?: number;
  7.   data?: string | Object | ArrayBuffer;
  8.   header?: Object;
  9.   expectDataType?: http.HttpDataType;
  10. }
  11. interface HttpResponse{
  12.    code:string|number;
  13.    message:string;
  14.    data:string|Object|unknown[]
  15. }
  16. export default  (config: httpConfig): Promise<HttpResponse>=> {
  17.   // 创建请求实例
  18.   const service = http.createHttp();
  19.   //请求地址
  20.   const url ='http://XXX.XXX' +config.url;
  21.   return new Promise((resolve, reject) => {
  22.     service.request(
  23.       url,
  24.       {
  25.         method: config.method,
  26.         expectDataType: config.expectDataType, //数据类型
  27.         header: {
  28.           "Content-Type":"application/json",
  29.           //header中存放身份信息
  30.           Authorization:"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9",
  31.           ...config.header,
  32.         },
  33.         extraData: config.data,
  34.         readTimeout:config.timeOut|| 50000,
  35.         connectTimeout:config.timeOut|| 50000
  36.       },
  37.       (err, response)=>{
  38.         if (!err && response.responseCode === 200) { //请求200
  39.           if (typeof response.result === 'string') {
  40.             const resData=  JSON.parse(response.result)
  41.             if(resData.code==2001){ //接口状态成功
  42.               resolve(resData)
  43.             }else{
  44.               // 接口约定好的状态码 例如登录过期 等等
  45.               DialogUtils.toast({message:'身份信息已失效,请重新登录'})
  46.               reject(response)
  47.             }
  48.           } else {
  49.             //接口返回数据异常
  50.             DialogUtils.toast({message:'网络请求错误,请稍后再试'})
  51.             reject(response)
  52.           }
  53.         } else {
  54.           // 状态码异常 例如 404 502 503 等等
  55.           // 请求失败通常是后端问题或者网络问题
  56.           checkStatus(response.responseCode)
  57.           reject(response)
  58.         }
  59.        }
  60.     )
  61.   })
  62. function  checkStatus(status: number): void {
  63.   let errMessage = '';
  64.   switch (status) {
  65.     case 400:
  66.       errMessage =  '网络请求超时!';
  67.       break;
  68.     case 401:
  69.       errMessage =  '用户没有权限(令牌、用户名、密码错误)!';
  70.       break;
  71.     case 403:
  72.       errMessage = '用户得到授权,但是访问是被禁止的!';
  73.       break;
  74.     case 404:
  75.       errMessage = '网络请求错误,未找到该资源!';
  76.       break;
  77.     case 405:
  78.       errMessage = '网络请求错误,请求方法未允许!';
  79.       break;
  80.     case 408:
  81.       errMessage = '网络请求超时!';
  82.       break;
  83.     case 500:
  84.       errMessage = '服务器错误,请联系管理员!';
  85.       break;
  86.     case 501:
  87.       errMessage = '网络未实现!';
  88.       break;
  89.     case 502:
  90.       errMessage = '网络错误!';
  91.       break;
  92.     case 503:
  93.       errMessage = '服务不可用,服务器暂时过载或维护!';
  94.       break;
  95.     case 504:
  96.       errMessage = '网络超时!';
  97.       break;
  98.     case 505:
  99.       errMessage = 'http版本不支持该请求!';
  100.       break;
  101.     default:
  102.   }
  103.   if (errMessage) {
  104.     // 进行错误提示
  105.     console.log('errMessage',errMessage)
  106.     DialogUtils.toast({message:errMessage})
  107.   }
  108. }
  109. }
复制代码

5. 封装业务接口

在ets/common/api下创建文件 index.ets 自己要根据实际业务举行调整这里只是示例 ,我在这里封装了一个 GET 一个POST 哀求。
  1. import request from "../utils/request";
  2. import http from '@ohos.net.http';
  3. // 数据列表
  4. export const listByCondition = (data:Record<string, string|number>) => {
  5.   return request({
  6.     url: "/wms/isoftstone-form-onlineoperation/listByCondition",
  7.     method: http.RequestMethod.POST,
  8.     data:data
  9.   });
  10. };
  11. // 字典列表
  12. export const dictList = (data:Record<string, string|number>) => {
  13.   return request({
  14.     url: "/wms/dict/list2",
  15.     method: http.RequestMethod.GET,
  16.     data:data
  17.   });
  18. };
复制代码
6. 项目中使用且哀求接口


                                            

在ets/pages/Index.ets 页面写入以下代码举行测试
  1. import  {listByCondition,dictList} from "../common/api/index"
  2. @Entry
  3. @Component
  4. struct Index {
  5.   @State listData:unknown[] = [];//数据列表
  6.   @State dicData:unknown[] = [];//字典列表
  7.   // 获取数据列表
  8.   async  getListByCondition(){
  9.     let res = await listByCondition({
  10.       "tableName":"cd_warehouse",
  11.       "columnName":"park_code",
  12.       "columnValue":"DCYQ01",
  13.       "filterType":1
  14.     });
  15.     this.listData = res.data as unknown[];
  16.   };
  17.   // 获取字典
  18.   async getDictList(){
  19.     let res = await dictList({
  20.       "code":"SYS_WMS_WORK_TYPE",
  21.     });
  22.     this.dicData = res.data as unknown[];
  23.   };
  24.   onPageShow(){
  25.     this.getListByCondition();
  26.     this.getDictList();
  27.   };
  28.   build() {
  29.     Column(){
  30.       Column(){
  31.         ForEach(this.listData, (item) => {
  32.           Row(){
  33.             Text(item.wh_code)
  34.             Text(item.cdwh_name)
  35.           }
  36.         })
  37.       }
  38.       Column(){
  39.         ForEach(this.dicData, (item) => {
  40.           Row(){
  41.             Text(item.value)
  42.             Text(item.label)
  43.           }
  44.         })
  45.       }
  46.     }
  47.     .height('100%')
  48.   }
  49. }
复制代码
到这里对http哀求二次封装就已经基本完成,本文只做了一些简单封装,主要是按照前端开发习惯举行封装,各人有须要可以参考学习。


末了
有很多小同伴不知道学习哪些鸿蒙开发技能?不知道须要重点掌握哪些鸿蒙应用开发知识点?但是又不知道从哪里下手,而且学习时频仍踩坑,终极浪费大量时间。所以本人整理了一些比较合适的鸿蒙(HarmonyOS NEXT)学习路径和一些资料的整理供小同伴学习
点击领取→纯血鸿蒙Next全套最新学习资料(安全链接,放心点击
希望这一份鸿蒙学习资料能够给各人带来帮助,有须要的小同伴自行领取,限时开源,先到先得~无套路领取!!
      
一、鸿蒙(HarmonyOS NEXT)最新学习门路

   

有了门路图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布条记整理收纳的一套体系性的鸿蒙(OpenHarmony )学习手册(共计1236页)与鸿蒙(OpenHarmony )开发入门教学视频,内容包含:(ArkTS、ArkUI开发组件、Stage模型、多端摆设、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技能、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)…等技能知识点。
获取以上完备版高清学习门路,请点击→纯血版全套鸿蒙HarmonyOS学习资料
二、HarmonyOS Next 最新全套视频教程


三、《鸿蒙 (OpenHarmony)开发基础到实战手册》
OpenHarmony北向、南向开发环境搭建

《鸿蒙开发基础》


  • ArkTS语言
  • 安装DevEco Studio
  • 运用你的第一个ArkTS应用
  • ArkUI声明式UI开发
  • .……

《鸿蒙开发进阶》


  • Stage模型入门
  • 网络管理
  • 数据管理
  • 电话服务
  • 分布式应用开发
  • 关照与窗口管理
  • 多媒体技能
  • 安全技能
  • 任务管理
  • WebGL
  • 国际化开发
  • 应用测试
  • DFX面向未来设计
  • 鸿蒙体系移植和裁剪定制
  • ……

《鸿蒙进阶实战》


  • ArkTS实践
  • UIAbility应用
  • 网络案例
  • ……

四、大厂口试必问口试题

五、鸿蒙南向开发技能

六、鸿蒙APP开发必备

七、鸿蒙生态应用开发白皮书V2.0PDF


完备鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料
总结
总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的期间中立于不败之地。 

                        



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

何小豆儿在此

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表