当前位置: 首页 > news >正文

全景图制作平台网站建设网络推广比较经典和常用的方法有

全景图制作平台网站建设,网络推广比较经典和常用的方法有,.net和php哪个做网站好,wordpress olam前景提要: ts 简易封装 axios,统一 API 实现在 config 中配置开关拦截器 请求重试的核心是可以重放请求,具体实现就是在 axios 中,拿到当前请求的 config 对象,再用 axios 实例,就能重放请求。 在无感刷新…

在这里插入图片描述

前景提要:
ts 简易封装 axios,统一 API
实现在 config 中配置开关拦截器

请求重试的核心是可以重放请求,具体实现就是在 axios 中,拿到当前请求的 config 对象,再用 axios 实例,就能重放请求。

在无感刷新 token 中,当 access token 过期,使用 refresh token 刷新后,就需要再次对业务接口重放请求。

上面是一种请求重试的场景,一般情况下也不需要重试,所以我们这里讲的请求重试,指的都是请求网络错误的情况下需要重试。
比如断网了,然后重试。而不是因为接口返回 code 如 401 就重试。因为接口返回 401,从网络层面上讲,这是没有失败的,http 状态码是 200,返回 401 只是业务失败。
比起断网,更常见的网络错误下需要重试的是请求超时。

通过错误拦截器实现请求重试。整个请求过程是一个递归。

第一次请求失败,触发全局错误拦截,然后一路抛出错误,触发到重试的错误拦截器。判断还有重试次数后,拿到同一个实例重放请求。注意此时第一次请求并未结束,this.instance.request 方法依旧在等待结果。
如果请求依旧失败,则触发第二次请求的全局错误拦截,最后再次触发重试。如果第二次请求重试成功了,此时就拿到了请求结果。并且为了让结果最终被第一次请求捕获,需要在错误拦截器中抛出 fulfilled 状态的 promise 携带结果。
当请求次数用完,则错误拦截器继续抛出错误对象,触发第一次请求的 request 方法的 catch 代码块。宣告整个请求失败。

注意:

  • 一定要以同一个 axios 实例重新发起请求,因为本质是递归,换个一个实例就拿不到重试成功后的请求结果了。
  • 并且还需要在这个重试的错误拦截器中返回一个 fulfilled 状态的 promise,让第一次请求的实例方法捕获。

return Promise.resolve(res); 或 Promise.rejected(234); 都表示返回一个确定了状态的 promise,然后这个 promise 中携带了数据(就是参数)。

import httpRequest from "..";
import { MyAxiosError, MyAxiosRequestConfig } from "./request";const MAX_RETRY_COUNT = 3;
const DELAY_TIME = 2000;let currentCount = 1;
/*** 请求重试* @param err 错误对象* @returns 重试机会用完抛出错误,重试成功则返回请求结果*/
export async function retryRequest(err: MyAxiosError) {if (err.config.retry === false) throw err;if (err.message === "canceled") throw err; // 过滤手动取消请求的情况const config = err.config as MyAxiosRequestConfig;if (MAX_RETRY_COUNT >= currentCount && config) {console.log(`重试${currentCount}次...`);currentCount++;await sleep(DELAY_TIME);const res = await httpRequest.getInstance().request({ ...config });return Promise.resolve(res);}console.log("重试次数已用完...");currentCount = 0;throw err;
}/*** 延迟后续代码执行的工具函数,以同步代码阻塞的方式实现延迟:await sleep()* @param delayTime 延迟时间* @returns Promise*/
export function sleep(delayTime: number = 1000) {return new Promise(resolve => setTimeout(resolve, delayTime));
}
http://www.shuangfujiaoyu.com/news/60623.html

相关文章:

  • html5响应式网站建设平台微商怎么做推广加好友
  • 容县网站开发火狐搜索引擎
  • 网站轮播代码seo站内优化公司
  • 二维码生成器微信小程序seo优化排名技术百度教程
  • 做网站域名怎么选有利于seo百度搜索指数是怎么计算的
  • 做影视网站规模不大培训课程网站
  • 沈阳网站建设58同城湖南网站建设营销推广
  • 华为官方网站手机商城快手作品免费推广软件
  • 建设银行 成都 招聘网站怎样做好销售和客户交流
  • 自己如何在网上做网站新泰网站seo
  • python基础教程电子书正版搜索引擎优化
  • 备案名称和网站名称不一致公司域名注册查询
  • 做bc网站排名设计网站都有哪些
  • 网站改版 权重seo公司推荐推广平台
  • 网站建站服务的公司驻马店百度seo
  • 音频网站建设微博指数
  • 泉州网站建设 推广百度 营销推广怎么操作
  • 网站开发过程的基本环节百度快照怎么发布
  • 定制网站开发冬天里的白玫瑰自己建网站怎么建
  • 做网站是什么课企业如何做网站
  • 一个网站seo做哪些工作建网站
  • 网站正在建设中亚洲企业培训课程名称
  • 做一个中英文双语网站建设多少钱推广平台排名
  • 那些做刷客的网站网络营销热点事件案例分析
  • 舞美设计制作公司seo是什么职务
  • 孝感做网站网站底部友情链接代码
  • 西安H5网站开发网站开发公司排名
  • web移动端网站开发案例市场推广方案ppt
  • 东莞做网站有哪些自己建网站怎么建
  • 免费申请网站永久域名发布软文的平台有哪些