javascript - vue中v-for和v-if結合的問題?
問題描述
利用v-for遍歷出N個關注按鈕,點擊其中一個關注按鈕,對應的關注按鈕變成已關注,第一次是這么做的
<img v-if=’flag’ @click=’change()’ :src=’countries[num]’ alt=''>//關注 <img v-if=’!flag’ :src=’countriesHasAttention[num]’ alt=''>// 已關注 data () {return { flag: true} }change: function () {this.flag = false }
發現點擊一個全都改變了,然后我把flag改成了一個數組
<img v-if=’flag[index]’ @click=’change(index)’ :src=’countries[num]’ alt=''> //關注<img v-if=’!flag[index]’ :src=’countriesHasAttention[num]’ alt=''> // 已關注data () {return { flag: [true, true, true]}} change: function (index) {this.flag[index] = false}發現這樣做點擊的時候按鈕不發生變化。求大神指導一下
問題解答
回答1:change部分改為Vue.set
change(index){ Vue.set(this.flag,index,false)}回答2:
模板可以簡化成這樣:
<img @click='change(index)' :src='http://www.leifengta.com.cn/wenda/flag[index] ? countries[num] : countriesHasAttention[num]' alt=''>
數據處理這一塊上面的答案是對的,參見:數組更新檢測
相關文章:
1. golang - 用IDE看docker源碼時的小問題2. 我何時應該在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)3. phpstudy8.1沒集成mysql-front4. 運行python程序時出現“應用程序發生異常”的內存錯誤?5. html - css氣泡,實現“倒三角(不知道算不算三角了)”可透明的。6. 利用IPMI遠程安裝centos報錯!7. 前端 - @media query 使用出現的問題?8. javascript - 請指條明路,angular的$event,在select中卻是undefined?9. html5和Flash對抗是什么情況?10. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””

網公網安備