淺析Vue中的Vue.set和this.$set,看看使用場景!

2022-03-04 19:00:49
本篇文章帶大家聊聊中的Vue.set和this.$set,介紹一下Vue.set和this.$set用法與使用場景,希望對大家有所幫助!

一、為什麼有Vue.set

由於JavaScript的限制,Vue無法檢測到data中陣列和物件的變化,因此也不會觸發檢視更新。vuejs視訊教學

二、解決方法

陣列

1.使用Vue提供的變異方法

1.png

Vue對這些JS陣列方法進行了封裝,通過這些方法是可以檢測到陣列更新的。

2.將原陣列整個替換

如下例中,是要實現vm.items[1] = 'excess'

<body>
<div id="app">
    <ul>
        <li v-for="(item, index) in items">
            {{ index }} : {{ item }}
        </li>
    </ul>
</div>

<script>
let vm = new Vue({
    el: '#app',
    data: {
        items: ['a', 'b', 'c']
    },
    created() {
        this.items = ['a', 'test', 'c']
    }
})
</script>
</body>

3.使用Vue.set(見後文)


物件

1.將原物件整個替換

如下例中,是要實現給object新增一個鍵值對{test: 'newthing'}

<body>
<div id="app">
    <ul>
        <li v-for="(value, name) in object">
            {{ name }} : {{ value }}
        </li>
    </ul>
</div>

<script>
let vm = new Vue({
    el: '#app',
    data: {
        object: {
            title: 'How to do lists in Vue',
            author: 'Jane Doe',
            publishedAt: '2016-04-10'
        }
    },
    created() {
        this.object = {
            title: 'How to do lists in Vue',
            author: 'Jane Doe',
            publishedAt: '2016-04-10',
            test: 'newthing'
        }
    }
})
</script>
</body>

2.使用Vue.set(見後文)


三、Vue.set

對於陣列

Vue不能檢測以下陣列的變動:

  • 利用索引值直接設定一個陣列項時,例如vm.list[0]=newValue
  • 修改陣列長度時,例如vm.list.length=newLength

舉個栗子

var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
  }
})
vm.items[1] = 'x' // 不是響應性的
vm.items.length = 2 // 不是響應性的

這時可以使用Vue.set或者this.$set

使用方法

Vue.set(target,index,newValue)

// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
// this.$set
vm.$set(vm.items, indexOfItem, newValue)

對於物件

Vue 無法檢測 property 的新增或移除。由於 Vue 會在初始化範例時對 property 執行 getter/setter 轉化,所以 property 必須在 data 物件上存在才能讓 Vue 將它轉換為響應式的。

舉個栗子

var vm = new Vue({
  data:{
    a:1
  }
})

// `vm.a` 是響應式的

vm.b = 2
// `vm.b` 是非響應式的

使用方法

Vue.set(target,key,value)

Vue.set(vm.someObject, 'b', 2)
this.$set(this.someObject,'b',2)

注意

Vue不允許動態新增根級響應式屬性

const app = new Vue({
  data: {
    a: 1
  }
  // render: h => h(Suduko)
}).$mount('#app1')

Vue.set(app.data, 'b', 2)

2.png

只可以使用 Vue.set(object, propertyName, value) 方法向巢狀物件新增響應式屬性

var vm=new Vue({
    el:'#test',
    data:{
        //data中已經存在info根屬性
        info:{
            name:'小明';
        }
    }
});
//給info新增一個性別屬性
Vue.set(vm.info,'sex','男');

四、使用場景

當我們對data中的陣列或物件進行修改時,有些操作方式是非響應式的,Vue檢測不到資料更新,因此也不會觸發檢視更新。此時需要使用Vue.set()進行響應式的資料更新。

(學習視訊分享:、)

以上就是淺析Vue中的Vue.set和this.$set,看看使用場景!的詳細內容,更多請關注TW511.COM其它相關文章!