JS中调用setInterval无效的情况怎样解决
Admin 2022-05-23 群英技术资讯 935 次浏览
使用场景:我在函数A中调用定时器函数,定时器是单独写的一个函数
原因:页面加载时我调用了1次函数A,然后又单独调用了一次定时器函数,导致调用了2次setInterval(),导致有setInterval_id有2个值。
通过打印定时器的值发现的问题。
clearInterval()只关闭了其中一个setInterval_id,另一个setInterval_id还会启动setInterval()。
解决方法:把单独调用的定时器函数去掉。
补充知识:js vue中setTimeout无法通过clearTimeout清除问题
在异步清除中,利用vue 中data存放setTimeout的标识进行清除时,无法清除。则需要在函数前加上window.即可
如window.setTimeout与window.clearTimeout
具体代码如下
精简后的代码。
环境为electron-vue 渲染进程异步获取主进程上html并渲染到页面、过程中需要有loading的显示。
setTimeout 与clearTimeout 未加window时,this.timeOutLoading事件总会被触发。
<template> <div id="dev"> <el-tabs v-model="activeName" @tab-click="handleClick" v-loading="loading"> <el-tab-pane label="文档" name="first"> <div v-html="html"></div> </el-tab-pane> <el-tab-pane label="设置" name="second"> <v-devCard></v-devCard> </el-tab-pane> </el-tabs> </div> </template> <script> const {ipcRenderer:ipc} = require('electron'); export default { data(){ return{ activeName: 'second', html:'', loading:false, timeOutLoading:0 } }, methods:{ handleClick(tab, event) { if(tab.name == 'first' && this.loading == false){ if(this.timeOutLoading != 0){ window.clearTimeout(this.timeOutLoading); } this.html = "<div style='text-align:center; height:200px; line-height:200px;'>加载中...</div>"; this.loading = true; this.timeOutLoading = window.setTimeout(() => { if(this.loading == true){ this.loading = false; this.html = "<div style='text-align:center; height:200px; line-height:200px;'>加载超时</div>"; } }, 3000); window.setTimeout(() => { ipc.send("getPage"); }, 500); } } }, mounted(){ ipc.on('getPage-reply', (event, arg) => { if(this.timeOutLoading != 0){ window.clearTimeout(this.timeOutLoading); this.timeOutLoading = 0; } this.loading = false; this.html = arg; }); } } </script>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
我们都知道urlencode编码一般用于url网址中,它的格式是带有 % 符号的十六进制编码,起着保护隐私的作用,例如这段url编码“%ce%d2%ca%c7%d6%d0%b9%fa%c8%cb(我是中国人)”,是gbk版本的,那么我们该如何来使用js解析这一段gbk2313的编码呢?代码如下: //
我们在平时写代码的时候偶尔会碰到进制转换的问题,常见的有2进制,8进制,10进制,16进制之间的转换,但是36进制却很少听过,这里就让我们用JS来简单尝试一下36进制的实现吧
本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了事件委托、判断URL是否合法以及全排列的相关内容,下面一起来看一下,希望对大家有帮助。
我们知道jquery中的组件有很多,但是也有可能找不到符合我们需求的组件,我们就可以自己封装一个组件。在JQ中,是允许我们自定义一些插件与扩展的。呢么jquery自定义组件的方法是什么呢?其实,定义的方式也比较简单,采用$.extend就行,那么下面就来看看在JQ中自定义一个插件的实例。
这篇文章主要为大家详细介绍了微信小程序自定义胶囊样式,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008