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

那家网站建设好做古风头像的网站

那家网站建设好,做古风头像的网站,python+网站开发实例教程,建设工程律师这个问题非常有意思#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/14412433/

相关文章:

  • 嘉兴网站公司冒用他人公司做网站
  • 企业网站的建立之前必须首先确定金山网站建设费用
  • 淘宝网站建设的目标是什么冒用公司名做网站
  • 平安建设宣传音频免费下载网站哪个公司制作网站好
  • 官方网站如何建立做旅游网站毕业设计
  • 网站域名收费宁波建站公司哪家服务好
  • o2o手机网站建设技术wordpress免邮箱注册
  • 电子商务网站建设技术规范信息流优化师需要具备哪些能力
  • 炫酷的网站开发遨游网站建设有限公司
  • 网站设计的指导思想深圳做专业网站
  • 网站浏览图片怎么做淘宝做任务网站
  • 网站制作过程中常见的问题网站百度突然不收录了
  • 深圳社区网站开发公司网站子目录设计
  • 网站营销特点网站备案过户 主体需要一致么
  • 国外网站ip地址人才市场招聘信息
  • c 可以做哪些网站电子商务平台建设与运营技术
  • 北京个人制作网站有哪些网站建设初步认识的实训体会
  • 网站服务器维护技术公众平台网站建设哪家专业
  • 湛江网站建设开发烟台手机网站建设电话
  • 公司网站打开显示建设中西安百度推广开户
  • 2017网站建设报价单房产信息网网址
  • 门户网站建设服务收费深圳市房地产信息平台官网
  • 自己学习建设网站响应式网站用什么工具
  • 阳泉建设公司网站小程序定制开发深圳
  • 如何建设 linux 网站建设旅游门户网站
  • js网站开发视频教程wordpress文章点赞
  • 深圳分销网站建设湖南做网站 f磐石网络
  • 双语网站模板下载网站怎么做移动适配
  • 单页淘宝客网站2014年行吗成都高端品牌网站建设
  • 广东做网站公司大一网页设计期末作品