在頁面中顯示數(shù)組數(shù)據(jù)時發(fā)現(xiàn)了一個問題,當(dāng)在methods方法中修改數(shù)組數(shù)據(jù)后,雖然數(shù)組已經(jīng)發(fā)生改變,但是改變后的數(shù)據(jù)并沒有渲染到頁面上。這是因為在VUE中,如果在實例創(chuàng)建之后添加新的屬性或者改變屬性到實例上,它將不會觸發(fā)視圖更新。
站在用戶的角度思考問題,與客戶深入溝通,找到塔城網(wǎng)站設(shè)計與塔城網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站設(shè)計制作、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、申請域名、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋塔城地區(qū)。
而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ù)的索引(第幾項)
value:修改后的值
實例
<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ù)組,點擊以后,考勤情況將會發(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ù)初始值全都是未知,點擊按鈕以后,attence()方法會根據(jù)傳入的參數(shù)改變數(shù)組中的值,傳入的參數(shù)是幾就改變第幾項的數(shù)據(jù)。頁面將會及時對數(shù)據(jù)變化作出響應(yīng),渲染出來。
注:該方法也可用來增加數(shù)據(jù),只需將第二項的索引值賦為數(shù)組的長度,第三項為增加的數(shù)據(jù)值。
以上這篇使用Vue.set()方法實現(xiàn)響應(yīng)式修改數(shù)組數(shù)據(jù)步驟就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持創(chuàng)新互聯(lián)。
本文題目:使用Vue.set()方法實現(xiàn)響應(yīng)式修改數(shù)組數(shù)據(jù)步驟
瀏覽地址:http://jinyejixie.com/article12/gpsigc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、App開發(fā)、網(wǎng)站建設(shè)、定制網(wǎng)站、域名注冊、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)