2021SC@SDUSC amis代码分析(9)

本文介绍了2021SC@SDUSC项目中Amis API请求的封装库,重点分析了normalizeApi、buildApi等关键函数,讨论了在大型项目中对数据对象处理的规范,以及请求和响应处理的流程,包括请求体构建、拦截处理和响应适配。
摘要由CSDN通过智能技术生成

2021SC@SDUSC

概述

本周分析学习amis的API请求的封装库api.ts,里面主要是amis对网络请求的自我封装处理方法。

关键函数

normalizeApi

处理 api,使其成为标准化、规范化的 API 对象。

// 用于正则匹配请求方法的正则表达式
const rSchema = /(?:^|raw\:)(get|post|put|delete|patch|options|head):/i;
export function normalizeApi(
  api: Api,
  defaultMethod: string = 'get' // 默认方法为 get 请求
): ApiObject {
   
  if (typeof api === 'string') {
    // 当 api 还是字符串类型时,将其处理成 API 对象
    let method = rSchema.test(api) ? RegExp.$1 : ''; // 匹配 api 中的请求方法,无则为空
    // method 存在时将其去除,剩下部分为请求的 url 
    method && (api = api.replace(method + ':', '')); 
    api = {
   
      method: (method || defaultMethod) as any, // 无则为默认的 defaultMethod
      url: api
    };
  } else {
    // 说明 api 已被处理过了,克隆 api
    api = {
   
      ...api
    };
  }
  return api;
}

从这段代码以及结合以前的代码,我们可以发现,大的开发项目中对于对象的处理很少是在原数据上直接修改,而是对目标数据进行克隆后再修改,返回新的对象,原始对象保持不变。为什么呢?第一,该对象可能在多处使用,一处改变处处受其影响。第二,原来数据的丢失不能再恢复,如果之后再需要时将不能再次获得。

buildApi

建立请求 api,该函数将 api 封装成一个完整的实体,对所有涉及到的请求类别都完美的适配处理。

export function buildApi(
  api: Api,
  data?: object,
  options: {
   
    autoAppend?: boolean; // 
    ignoreData?: boolean; // 是否忽略请求体数据
    [propName: string]: any;
  } = {
   }
): ApiObject {
   
  api = normalizeApi(api, options.method); // api 请求标准化
  const {
   autoAppend, ignoreData, ...rest} = options; // 可选参数解析
  // rest 是自定义的请求配置项
  api.config = {
   
    ...rest
  };
  // api.method 来自于规则化后的 api.method | options 中的自定义配置项 | 默认的 get
  // 其实此时 api.method 已经满足要求了,我不太清楚这样反复检测的目的,难道还有特殊情况?
  api.method = (api.method || (options as any).method || 'get').toLowerCase();

  if (!data) {
    // 没有数据,直接不用考虑了
    return api;
  } else if (
    // 携带的 data 是 FormData(表单数据) | Blob(二进制文件) | ArrayBuffer(buffer数组)
    data instanceof FormData ||
    data instanceof Blob ||
    data instanceof ArrayBuffer
  ) {
   
    api.data = data; // 可直接传输,直接赋给 api.data 字段
    return api;
  }
  // 下面处理 get 请求中携带在 url 中的数据
  // 这里也不太理解,api.url = api.url 不是赋值语句吗?恒成立啊
  // raw = api.url
  const raw = (api.url = api.url || '');
  // 找到 api.url 中的 ?
  const idx = api.url.indexOf('?');
  // 包含 ?
  if (~idx) {
   
    // # 后的参数是该页面内的参数,不是请求数据;如果包含 # ,其后不用考虑
    const hashIdx = api.url.indexOf('#');
    // 将其处理成键值对的参数列表
    const params = qsparse(
      // 从 ? 到 #
      api.url.substring(idx + 1, ~hashIdx ? hashIdx : undefined)
    );
    api.url =
      // 将主 url 处理后再与其余部分结合
      tokenize(api.url.substring(0, idx 
此版本更新内容包括:Feature :sparkles: 新增 sortBy 和 topAndOther filter (#1378) (#1379) api 新增 responseData 配置 (#1379) 添加季度选择器 Quarter (#1382) Container 支持设置样式 (#1411) 加入 ecStat, Apache ECharts (incubating) 的统计和数据挖掘工具 (#1419) Form 支持 feedback (#1420) 新增仿 antd 主题 (#1421) Enhancement jssdk 支持外部监控路由变化重新切换页面 (#1373) 选择类表单项 selectFirst 跳过 disabled 的选项 (#1393) iconfont 发布到 sdk 里 (#1395) api mock 地址替换 (#1408) Echarts 没数据时显示 loading (#1409) Breaking :翻译文件的 key 不再是中文,如果有修改过英文翻译,需要换成新 key (#1416) (#1418) 拆解 factory.tsx,添加 RootRenderer,并能 处理部分 action, 直接渲染个按钮也能弹窗,发ajax了 (#1425) Text 配置 source 样式优化 (#1429) 更换 autobind,继承时 this 不错乱 (#1433) Bugfix 修复 表单项在不配置 name 的时候,value 属性失效问题 (#1372) 修复 Excel 导出的列顺序依照配置的顺序,而不是数据源 (#1377) 修复 ChartRadios tooltip 问题. (#1378) 修复 位置选择组件在新版百度地图 api 下无法使用问题 (#1381) 修复 表单项有多个的时候,回车不提交问题 (#1387) 修复 helper 中 white-space 不正确问题 (#1390) 修复 Excel 导出不支持嵌套 name 和 tpl 问题 (#1424) 修复 收起状态导航菜单不可点击跳转问题 (#1428) 修复 Checkbox 无 disabled 样式问题 (#1414)amis前端低代码框架是一个低代码前端框架,它使用 JSON 配置来生成页面,可以节省页面开发工作量,极大提升开发前端页面的效率。 目前在百度广泛用于内部平台的前端开发,已有 100+ 部门使用,创建了 3w+ 页面。amis前端低代码框架特点1、不需要懂前端:在百度内部,大部分 amis 用户之前从来没写过前端页面,也不会 JavaScript,却能做出专业且复杂的后台界面,这是所有其他前端 UI 库都无法做到的; 2、不受前端技术更新的影响:百度内部最老的 amis 页面是 4 年多前创建的,至今还在使用,而当年的 Angular/Vue/React 版本现在都废弃了,当年流行的 Gulp 也被 Webpack 取代了,如果这些页面不是用 amis,现在的维护成本会很高; 3、享受 amis 的不断升级:amis 一直在提升细节交互体验,比如表格首行冻结、下拉框大数据下不卡顿等,之前的 JSON 配置完全不需要修改; 4、可以完全使用可视化页面编辑器 来制作页面:一般前端可视化编辑器只能用来做静态原型,而 amis 可视化编辑器做出的页面是可以直接上线的。 5、提供完整的界面解决方案:其它 UI 框架必须使用 JavaScript 来组装业务逻辑,而 amis 只需 JSON 配置就能完成完整功能开发,包括数据获取、表单提交及验证等功能,做出来的页面不需要经过二次开发就能直接上线; 6、内置 100+ 种 UI 组件:包括其它 UI 框架都不会提供的富文本编辑器、条件组合等,能满足各种页面组件展现的需求,而且对于特殊的展现形式还可以通过 自定义组件 来扩充; 7、容器支持无限级嵌套:可以通过组合来满足各种布局需求; 8、经历了长时间的实战考验:amis 在百度内部得到了广泛使用,在 4 年多的时间里创建了 3 万+ 页面,从内容审核到机器管理,从数据分析到模型训练,amis 满足了各种各样的页面需求,最复杂的页面有超过 1 万行 JSON 配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值