vue列表數(shù)據(jù)發(fā)生變化指令沒有更新問題及解決方法
問題描述,在vue的for循環(huán)中使用了指令,然后對數(shù)據(jù)進行篩選的時候,發(fā)現(xiàn)指令沒有起作用。
如圖前面的圖標是根據(jù)文件名的后綴名,返回響應(yīng)圖標的,通過指令實現(xiàn)的。然后我們在搜索框中刪選以后,數(shù)據(jù)更新了,但是圖標沒有更新
分析原因
<div v-for="(item, index) in myDate" :key='index'> ... </div>
問題就出在了:key='index'因為vue中for循環(huán)是根據(jù)key的值的變化來更新vnode的,很顯然我們經(jīng)過篩選如果刪選出三條數(shù)據(jù),那么index = 0, 1, 2沒有變化,所以vnode沒有更新
解決辦法1:我們設(shè)置:key的時候最好使用每條數(shù)據(jù)的id這樣就是唯一的,每次篩選,vnode都會更新。
解決辦法2:在指令中設(shè)置
// 添加bind設(shè)置
bind: function (el, binding, vnode) {
// bind中的vnode里面的key可以給設(shè)置一個隨機數(shù),這樣每次都會更新虛擬節(jié)點。
let num = parseInt(Math.random() * 10)
vnode.key = num
},
inserted: ...
總結(jié)
以上所述是小編給大家介紹的vue列表數(shù)據(jù)發(fā)生變化指令沒有更新問題及解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Vue3+TS實現(xiàn)數(shù)字滾動效果CountTo組件
最近開發(fā)有個需求需要酷炫的文字滾動效果,發(fā)現(xiàn)vue2版本的CountTo組件不適用與Vue3,沒有輪子咋辦,那咱造一個唄,感興趣的小伙伴可以跟隨小編一起了解一下2022-11-11
VUE2.0自定義指令與v-if沖突導(dǎo)致元素屬性修改錯位問題及解決方法
這篇文章主要介紹了VUE2.0自定義指令與v-if沖突導(dǎo)致元素屬性修改錯位問題及解決方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07
vue中this.$router.push()路由傳值和獲取的兩種常見方法匯總
這篇文章主要介紹了vue中this.$router.push()路由傳值和獲取的兩種常見方法,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-12-12
Vue cli構(gòu)建及項目打包以及出現(xiàn)的問題解決
這篇文章主要介紹了Vue cli構(gòu)建及項目打包以及出現(xiàn)的問題解決,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
vue跳轉(zhuǎn)頁面的幾種常用方法實例總結(jié)
Vue是一種流行的JavaScript框架,用于構(gòu)建用戶界面,在Vue中,頁面跳轉(zhuǎn)通常使用路由(Router)來實現(xiàn),除此之外還有很多方法,這篇文章主要給大家介紹了關(guān)于vue跳轉(zhuǎn)頁面的幾種常用方法,需要的朋友可以參考下2024-05-05

