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

北京做网站个人长春最新发布信息

北京做网站个人,长春最新发布信息,日本做a爱片视频网站,公司网站建设的分类背景 众所周知,后端是处理不了复杂的任务的,所以经过人家的技术讨论之后,把业务放在前端来实现。记录一下这次的离大谱需求吧。 如图所示,这个页面有5个列表,默认加载计划列表。但是由于后端的种种原因,这…

背景

众所周知,后端是处理不了复杂的任务的,所以经过人家的技术讨论之后,把业务放在前端来实现。记录一下这次的离大谱需求吧。

如图所示,这个页面有5个列表,默认加载计划列表。但是由于后端的种种原因,这个列表接口不能直接调取。

要先调一个查询状态的接口,每 3s 轮询一次,如果返回的计划状态字段campaign为 true,才可以调列表page接口。

如果 30s 的时候还没为 true,表格的加载文案变成“数据量较大,拼命加载中,请耐心等待”。

如果2min的时候还没为 true,停止轮询,表格显示为“数据量较大,加载超时,请稍后”,提供一个重试按钮。

实现思路

首先定义一个全局变量-定时器。

在页面初始化的时候,加载loadData方法,如果定时器存在,清除定时器,防止污染。

定义一个方法lockData,在loadData函数中调用,这个方法的参数为一个异步函数的处理结果,这个异步函数就是查询状态,如果返回的计划状态为真,则调取列表接口,return false,否则return 接口的响应结果(一个对象)

在lockData方法中,定义一个秒数参数curTime,再定义清除定时器的方法。如果定时器不存在,先接收参数,看看查询结果是什么。如果这个参数为 false ,说明之前查询状态的结果是真已经直接调page接口了,此时直接return,结束方法。否则,开启定时器,秒数自增,如果秒数能整除3,且参数存在,调取参数,拿到返回结果,如果结果为 false,则清除定时器。如果curTime 大于200,清除定时器,让表格显示超时样式。

代码如下:

async lockData(func) {let curTime = 0const clearI = () => {clearInterval(Interval)Interval = nullcurTime = 0this.loadingText = ''this.loading = false}if (!Interval) {this.loading = truelet isClear = await func()if (!isClear) returnInterval = setInterval(async () => {curTime++if (curTime >= 30) {this.loadingText = '数据量较大,拼命加载中,请耐心等待'}if (curTime % 3 === 0) {if (func) {let isClear = await func()console.log('lockData', { curTime, isClear })if (!isClear) clearI()}}if (curTime >= 120) {clearI()this.tableData = []this.timeOutEmpty = true}}, 1000)this.$once('hook:beforeDestroy', () => {clearInterval(Interval)})}
},
async loadData() {if(Interval) {clearInterval(Interval)Interval = null}this.timeOutEmpty = falsethis.lockData(async () => {let response = await this.dataSync()return response})
},
async dataSync() {this.loading = truelet response = await this.$axios.post('/xxxxx/baseToday', {xxxx})if (response.data.status === 0 && response.data.data['campaign']) {await this.getData()return false}return response
},
async getData() {this.loading = truelet response = await this.$axios.post('/xxxx/page', {xxxx})if (response.data.status === 0) {this.tableData = response.data.listthis.total = response.data.totalCountthis.$emit('changeTotal', {key: 'campaignNum',value: this.total})}this.loading = false
}
<div slot="empty"><div v-if="timeOutEmpty"><span>数据量较大,加载超时,请稍后<el-button @click="loadData" type="text">重试</el-button></span></div><span v-else>暂无数据</span>
</div>
http://www.tj-hxxt.cn/news/39931.html

相关文章:

  • 在演示文稿上网站怎么做广告营销策略
  • 高端网站哪种好广东seo快速排名
  • 怎样重装电脑wordpressseo推广的公司
  • 网上开店需要多少钱?关键词seo优化软件
  • 做网站有一行一行写代码的吗西安网站seo公司
  • 宁波做网站费用网站优化入门免费教程
  • 成都网站建设找亮帅百度 营销推广多少钱
  • 高端t恤定制网站百度推广登录入口登录
  • 做影视网站需要多大硬盘营销推广内容
  • 北京著名的网站制作公司关键词挖掘工具网站
  • 凡科网站可以做seo优化信息发布网站有哪些
  • 建设部网站执业资格营销到底是干嘛的
  • 网站建站模式产品推广文案
  • 做的网站 只显示代码制作网站需要多少费用
  • 凡科做的网站百度收不收录百度热榜实时热点
  • 网站设计报价表搜索引擎营销的原理是什么
  • 在线网页制作网站域名查询系统
  • 网站制作公司 北京活动推广宣传方案
  • seo网站推广优化桂林市天气预报
  • 免费行情软件下载入口武汉整站seo数据上云
  • 营销型网站定制贵州萝岗seo整站优化
  • 通用搭建网站教程上海网站制作推广
  • 长春市网络科技有限公司seo是做什么工作的
  • wordpress如何更改字体大小长春seo外包
  • wordpress导航站模板少儿编程培训机构排名前十
  • 桂林象鼻山门票seo自动优化软件安卓
  • 新手做网站应该注意什么搜索引擎推广方式有哪些
  • 外贸生意做哪个网站好今天的新闻 最新消息
  • 做的网站怎么转成网址链接1688官网入口
  • 建设网站报价济南做seo排名