关于vue中的及时响应问题Vue.set()

在我们使用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>




猜你喜欢

转载自blog.csdn.net/beichen3997/article/details/80739028