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

建建设网站的漳州网站建设去博大a优

建建设网站的,漳州网站建设去博大a优,代理注册公司的风险,徐州社交网站这个问题非常有意思#xff0c;我一看到就想了很多可以回复的答案#xff0c;但是评论区太窄#xff0c;就直接开一篇文章来写了。 审题 JS 发起的请求可以暂停吗#xff1f;这一句话当中有两个概念需要明确#xff0c;一是什么样的状态才能称之为 暂停#xff1f;二是…这个问题非常有意思我一看到就想了很多可以回复的答案但是评论区太窄就直接开一篇文章来写了。 审题 JS 发起的请求可以暂停吗这一句话当中有两个概念需要明确一是什么样的状态才能称之为 暂停二是 JS 发起的请求 是什么 怎么样才算暂停 暂停 全称暂时停止在已开始未结束的过程中临时停止可以称之为暂停意味着这个过程可以在某个时间点截断然后在另一个时间点重新续上。 请求应该是什么 这里得先介绍一下 TCP/IP 网络模型 网络模型自上而下分为 应用层、传输层、网络层和网络接口层。 上图表示的意思是每次网络传输应用数据在发送至目标前都需要通过网络模型一层一层的包装就像寄快递一样把要寄的物品先打包好登记一下大小再装在盒子里登记一下目的地然后再装到车上最后送往目的地。 请求(Request) 这个概念就可以理解为客户端通过若干次数据网络传输将单份数据完整发给服务端的行为而针对某次请求服务端往客户端发送的答复数据则可以称之为 响应(Response)。 理论上应用层的协议可以通过类似于标记数据包序列号等等一系列手段来实现暂停机制。但是 TCP 协议并不支持TCP 协议的数据传输是流式的数据被视为一连串的字节流。客户端发送的数据会被拆分成多个 TCP 段TCP segments而这些段在网络中是独立传输的无法直接控制每个 TCP 段的传输因此也无法实现暂停请求或者暂停响应的功能。 解答提问 如果请求是指网络模型中的一次请求传输那理所当然是不可能暂停的。 来看看提问者的使用场景 —— JS 发起的请求那么可以认为问题当中的请求应该是指在 JS 运行时中发起的 XMLHttpRequest 或者是 fetch 请求而请求既然已经发起那问的自然就是 响应是否能够被暂停 。 我们都知道像大文件分片上传、以及分片下载之类的功能本质上是将分片顺序定好之后按顺序请求然后就可以通过中断顺序并记录中断点来实现暂停重传的机制而单个请求并不具备这样的环境。 用 JS 实现 ”假暂停” 机制 虽然不能真正意义上实现暂停请求但是我们其实可以模拟一个 假暂停 的功能在前端的业务场景上数据不是收到就可以直接打在客户脸上的什么光速打击前端开发者需要对这些数据进行处理之后渲染在界面上如果我们能在请求发起之前增加一个控制器在请求回来时如果控制器为暂停状态则不处理数据等待控制器恢复后再进行处理是不是也能到达到目的让我们试着实现一下。 假如我们使用 fetch 来请求。我们可以设计一个控制器 Promise 和请求放在一起用 Promise.all 包裹当 fetch 完成时判断这个控制器的暂停状态如果没有被暂停则控制器也直接 resolve同时整个 Promise.all 也 resolve 抛出。 function _request () {return new Promisenumber((res) setTimeout(() {res(123)}, 3000)) }// 原本想使用 class extends Promise 来实现 // 结果一直出现这个问题 https://github.com/nodejs/node/issues/13678 function createPauseControllerPromise () {const result {isPause: false,resolveWhenResume: false,resolve (value?: any) {},pause () {this.isPause true},resume () {if (!this.isPause) returnthis.isPause falseif (this.resolveWhenResume) {this.resolve()}},promise: Promise.resolve()}const promise new Promisevoid((res) {result.resolve res})result.promise promisereturn result }function requestWithPauseControl T extends () Promiseany(request: T) {const controller createPauseControllerPromise()const controlRequest request().then((data) {if (!controller.isPause) controller.resolve()return data}).finally(() {controller.resolveWhenResume true})const result Promise.all([controlRequest, controller.promise]).then(data {controller.resolve()return data[0]});(result as any).pause controller.pause.bind(controller);(result as any).resume controller.resume.bind(controller);return result as ReturnTypeT { pause: () void, resume: () void } }用法 我们可以通过调用 requestWithPauseControl(_request) 来替代调用 _request 使用通过返回的 pause 和 resume 方法控制暂停和继续。 const result requestWithPauseControl(_request).then((data) {console.log(data) })if (Math.random() 0.5) { result.pause() }setTimeout(() {result.resume() }, 4000)最后 以上就是本篇文章分享的全部内容了。 这里是 Xekin/zi:kin/。喜欢的掘友们可以点赞关注点个收藏~ 最近摸鱼时间比较多写了一些奇奇怪怪有用但又不是特别有用的工具不过还是非常有意思的之后会一一写文章分享出来感谢各位支持。 前端面试题库 面试必备            推荐★★★★★ 地址前端面试题库
http://www.hkea.cn/news/14480768/

相关文章:

  • 青岛建站费用仿 手机 网站模板html源码
  • 选片 网站 建设微商客源人脉app下载
  • 用个人的信息备案网站什么网站可以接装修活
  • 国内有做网游评测的网站么海口制作网站
  • 网站建设规划书河北做网站的公司在哪
  • 方维制网站重庆做网站最好的
  • 如何用ps做网站界面国家重点高新技术企业名单
  • 网站不换域名换空间做视频解析网站
  • 网站建设合同书(范本)淘宝网站建设教程视频教程
  • 设计手机网站公司建设官方网站请示
  • 惠州网站小程序建设建设银行信用卡网站查询
  • 编程 朋友 做网站建网站要多少费用
  • 备案网站建设方案书全景网投资者关系互动平台
  • 广州市照明建设管理中心网站3030wa网站开发学校
  • 定制产品网站一键logo生成器
  • 二手车网站模板建设镇江网站制作价格
  • 网站建设公司的发展前景制作企业网站页面多少钱
  • 网站设置仅某浏览器大数据营销的作用
  • 网站流程图制作软件张家港 网站制作
  • 网站建设外包建设公司官方网站首页
  • 开发网站私活免费学做网站
  • 建网站的模块简述网站建设在作用
  • 公司内部网站系统义乌做网站公司哪家好
  • 霸州网站建设学校文化建设网站
  • 漯河市源汇区建设局网站万网解压缩wordpress
  • 自己学建网站软件开发专业大专学校排名
  • .net 网站开发视频南宁市建设厅网站
  • 徐州建设工程网站产品宣传短视频制作
  • 网站建设网站优化织梦怎么查看网站点击
  • 深圳华宫建设集团网站医院门户网站建设方案