在vue中使用setInterval的方法示例
昨天在用vue開發(fā)項目的時候遇到一個坑,在群友的探討中,成功的解決了這一問題。
具體情形如下:使用vue開發(fā),在頁面中有一個人數(shù)統(tǒng)計組件,人數(shù)統(tǒng)計是要動態(tài)變化數(shù)據(jù)的,由于目前沒有真實數(shù)據(jù),那么我想的是用隨機數(shù)和setInterval來改變data里面的數(shù)據(jù),從而做到數(shù)據(jù)實時變化,這樣方便與我來做數(shù)字翻頁動畫。
代碼如下:
<template>
<div class="totel-number">
<div class="panel-top">
<div class="panel-top_Left"></div>
<div class="panel-top_Text flex-center" >數(shù)量</div>
<div class="panel-top_Right"></div>
</div>
<div class="panel-body">
<div class="counter-wrap">
<ul class="counter-board">
<li class="num-board" v-for="item in totelNumber">
<span class="num u">
<i class="w">{{item}}</i>
</span>
<span class="num b">
<i class="w">{{item}}</i>
</span>
</li>
</ul>
</div>
</div>
<i class="cc-Corner cc-C-t cc-C-l"></i>
<i class="cc-Corner cc-C-t cc-C-r"></i>
<i class="cc-Corner cc-C-b cc-C-r"></i>
<i class="cc-Corner cc-C-b cc-C-l"></i>
</div>
</template>
<script>
import $ from 'jquery'
import * as d3 from 'd3';
export default {
data(){
return {
totelNumber: new Array(8)
}
},
beforeMount() {
//設(shè)置定時器,每3秒刷新一次
var self = this;
setInterval(getTotelNumber,1000)
function getTotelNumber() {
for(let i=0; i < self.totelNumber.length; i++){
self.totelNumber[i] = Math.ceil(Math.random()*10) -1
}
}
getTotelNumber();
}
}
</script>
大家有發(fā)現(xiàn)問題嗎?
在beforeMount里面console.log(this.totelNumber)會發(fā)現(xiàn)數(shù)據(jù)是在變化的,但是頁面上是沒有任何變化。
這是什么原因呢?
方法:先把問題分解開,就懷疑的幾個點做正反的驗證
在多次驗證在多次驗證和查看文檔后強哥找到了:
需要注意的是有兩種情況不會觸發(fā)視圖更新,需要換種變通寫法:
- 當(dāng)你利用索引直接設(shè)置一個項時,例如: vm.items[indexOfItem] = newValue
- 當(dāng)你修改數(shù)組的長度時,例如: vm.items.length = newLength
更具這個思路我就明白了為什么會有這樣的坑,然后就將代碼進(jìn)行了改進(jìn):
<script>
import $ from 'jquery'
import * as d3 from 'd3';
export default {
data(){
return {
totelNumber: new Array(8)
}
},
beforeMount() {
//設(shè)置定時器,每3秒刷新一次
var self = this;
setInterval(getTotelNumber,1000)
function getTotelNumber() {
let newArray = new Array(8)
for(let i=0; i < this.totelNumber.length; i++){
newArray[i] = Math.ceil(Math.random()*10) -1
}
self.totelNumber = newArray
}
getTotelNumber();
}
}
</script>
如此一來就可將數(shù)據(jù)實時動態(tài)刷新呈現(xiàn)在頁面上。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue $mount實戰(zhàn)之實現(xiàn)消息彈窗組件
這篇文章主要介紹了Vue $mount實現(xiàn)消息彈窗組件的相關(guān)知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04
vue中el-autocomplete與el-select的異同
本文主要介紹了vue中el-autocomplete與el-select的異同,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
vue使用echarts實現(xiàn)動態(tài)數(shù)據(jù)的示例詳解
這篇文章主要為大家詳細(xì)介紹了vue如何使用echarts實現(xiàn)動態(tài)數(shù)據(jù),文中的示例講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11
關(guān)于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài)
這篇文章主要介紹了關(guān)于Elementui中toggleRowSelection()方法實現(xiàn)分頁切換時記錄之前選中的狀態(tài),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能
這篇文章主要介紹了Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03

