欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Vue.set()方法實(shí)現(xiàn)響應(yīng)式修改數(shù)組數(shù)據(jù)步驟

 更新時間:2019年11月09日 16:40:45   作者:marsur  
今天小編就為大家分享一篇使用Vue.set()方法實(shí)現(xiàn)響應(yīng)式修改數(shù)組數(shù)據(jù)步驟,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在頁面中顯示數(shù)組數(shù)據(jù)時發(fā)現(xiàn)了一個問題,當(dāng)在methods方法中修改數(shù)組數(shù)據(jù)后,雖然數(shù)組已經(jīng)發(fā)生改變,但是改變后的數(shù)據(jù)并沒有渲染到頁面上。這是因?yàn)樵赩UE中,如果在實(shí)例創(chuàng)建之后添加新的屬性或者改變屬性到實(shí)例上,它將不會觸發(fā)視圖更新。

而Vue.set()方法能夠確保響應(yīng)式對象被創(chuàng)建后仍然是響應(yīng)式的,同時觸發(fā)視圖更新,動態(tài)響應(yīng)數(shù)據(jù)的變化。

用法如下:

Vue.set(object,index,value)

object:要更改的數(shù)據(jù)源(數(shù)組或?qū)ο螅?/p>

index:數(shù)據(jù)的索引(第幾項(xiàng))

value:修改后的值

實(shí)例

   <div v-for="(item,index) in state">
    <div class="student">
    <span>
     <img src="./../../../assets/icon.jpg">
     <span>小五</span>
    </span>
     <span><button @click="attence(index)">{{item}}</button></span>
    </div>
   </div>

該頁面的考勤情況數(shù)據(jù)來源于一個數(shù)組,點(diǎn)擊以后,考勤情況將會發(fā)生改變。

data(){
    return{
     id:1,
     state:['未知','未知','未知','未知','未知','未知','未知','未知','未知']
    }
   },
   methods:{
    attence:function(num){
     if(this.state[num]=='未知'){
      Vue.set(this.state,num,'出勤');
     }
     else if(this.state[num]=='出勤'){
      Vue.set(this.state,num,'請假');
     }
     else if(this.state[num]=='請假'){
      Vue.set(this.state,num,'缺勤');
     }
     else if(this.state[num]=='缺勤'){
      Vue.set(this.state,num,'未知');
     }
    }
   }

在這段代碼中,數(shù)組中的數(shù)據(jù)初始值全都是未知,點(diǎn)擊按鈕以后,attence()方法會根據(jù)傳入的參數(shù)改變數(shù)組中的值,傳入的參數(shù)是幾就改變第幾項(xiàng)的數(shù)據(jù)。頁面將會及時對數(shù)據(jù)變化作出響應(yīng),渲染出來。

注:該方法也可用來增加數(shù)據(jù),只需將第二項(xiàng)的索引值賦為數(shù)組的長度,第三項(xiàng)為增加的數(shù)據(jù)值。

以上這篇使用Vue.set()方法實(shí)現(xiàn)響應(yīng)式修改數(shù)組數(shù)據(jù)步驟就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論