我使用setInterval实现参数mytime 10,每5秒添加一次。
例如,我希望得到一个像1 11 21 31 41这样的结果列表.
但真正的结果序列是1 11 31 71 151 311.
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<script src="https://cdn.bootcss.com/vue/2.3.4/vue.js"></script>
</head>
<body>
<div id="app-6">
{{ aaa() }}
</div>
</body>
</html>
<script>
var app6 = new Vue({
el: '#app-6',
data: {
mytime: 1
},
methods: {
aaa: function() {
setInterval(() => {
this.bbb()
}, 5000);
return this.mytime;
},
bbb: function() {
this.mytime = this.mytime + 10;
},
}
})
</script>
发布于 2018-03-17 18:29:09
每次重新呈现时,它都会再次调用aaa()。每次调用这个函数时,它都会设置一个新的定时器。
每次设置计时器时,它都会添加多次:
10 (因为只有一个定时器),但是第一个添加会再次触发aaa(),这会创建一个额外的计时器10,从11一直到31。但是这种改变也会触发aaa(),它也会创建新的计时器,而且这种情况还在继续.解决方案:我的建议是将{{ mytime }}添加到模板中,并只在created()生命周期挂钩时触发setInterval()。
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<script src="https://cdn.bootcss.com/vue/2.3.4/vue.js"></script>
</head>
<body>
<div id="app-6">
{{ mytime }}
</div>
<script>
var app6 = new Vue({
el: '#app-6',
data: {
mytime: 1
},
created() {
setInterval(() => {
this.bbb()
}, 5000);
},
methods: {
bbb: function() {
this.mytime = this.mytime + 10;
},
}
})
</script>
</body>
</html>
https://stackoverflow.com/questions/49340207
复制相似问题