在我们使用vue的过程中,有时会遇到这么一种情况,
<html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="./js/vue.min.js"></script> </head> <body> <div id="app"> <ul> <li v-for="item in listData">{{item}}</li> </ul> <a href="javascript:void(0)" v-text="he" @click="changeData()"></a> </div> </body> <script> new Vue({ el:"#app", data:{ he:"点我", listData:["1","2","3"] }, methods:{ changeData () { this.listData[0]="s"; } } }) </script> </html>
当我点击按钮时候,发现没有任何变化,页面上还是1,2,3
这时怎么办呢
Vue.set()
官方解释
设置对象的属性。如果对象是响应式的,确保属性被创建后也是响应式的,同时触发视图更新。这个方法主要用于避开 Vue 不能检测属性被添加的限制。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="./js/vue.min.js"></script> </head> <body> <div id="app"> <ul> <li v-for="item in listData">{{item}}</li> </ul> <a href="javascript:void(0)" v-text="he" @click="changeData()"></a> </div> </body> <script> new Vue({ el:"#app", data:{ he:"点我", listData:["1","2","3"] }, methods:{ changeData () { Vue.set(this.listData,0,'s') } } }) </script> </html>