中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

setInterval怎么在vue中使用

發布時間:2021-04-07 15:43:37 來源:億速云 閱讀:194 作者:Leah 欄目:web開發

setInterval怎么在vue中使用?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

代碼如下:

<template>
  <div class="totel-number">
    <div class="panel-top">
      <div class="panel-top_Left"></div>
      <div class="panel-top_Text flex-center" >數量</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() {
     //設置定時器,每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>

大家有發現問題嗎?

在beforeMount里面console.log(this.totelNumber)會發現數據是在變化的,但是頁面上是沒有任何變化。

這是什么原因呢?

方法:先把問題分解開,就懷疑的幾個點做正反的驗證

在多次驗證在多次驗證和查看文檔后強哥找到了:

需要注意的是有兩種情況不會觸發視圖更新,需要換種變通寫法:

- 當你利用索引直接設置一個項時,例如: vm.items[indexOfItem] = newValue
- 當你修改數組的長度時,例如: vm.items.length = newLength

更具這個思路我就明白了為什么會有這樣的坑,然后就將代碼進行了改進:

<script>
import $ from 'jquery'
import * as d3 from 'd3';
export default {
  data(){
    return {
      totelNumber: new Array(8)
    }
  },
  beforeMount() {
     //設置定時器,每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>

關于setInterval怎么在vue中使用問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

津市市| 卫辉市| 九江市| 双牌县| 荔浦县| 当涂县| 化德县| 贡山| 西安市| 郯城县| 海宁市| 乡宁县| 奇台县| 盱眙县| 常州市| 元阳县| 普陀区| 宝丰县| 桃园县| 锡林郭勒盟| 乐至县| 邮箱| 邳州市| 浮梁县| 南阳市| 封丘县| 中山市| 安仁县| 福鼎市| 呼和浩特市| 临江市| 五大连池市| 泗洪县| 湟源县| 望谟县| 邹平县| 沙河市| 德阳市| 会昌县| 九寨沟县| 宁陵县|