當我們在使用Vue.js的時候,我們經(jīng)常需要在實例化后更新一個屬性或者視圖。在一些情況下,這個需要更新的屬性并沒有在創(chuàng)建實例時進行初始化。假設我們有一個空數(shù)組,在運行時我們需要向其中添加新的元素。在這種情況下,我們需要使用Vue提供的set方法來進行更新。Vue.set方法可以用于添加、刪除、修改數(shù)組和對象。
// 定義一個空數(shù)組 var myArray = [] // 向myArray數(shù)組中添加新的選項并添加至Vue實例中 Vue.set(myArray, 'index', '新的選項') // 使用$set方法對myArray數(shù)組進行更新并添加至Vue實例中 this.$set(myArray, 'index', '新的選項')
我們可以通過兩種方式來使用Vue.set方法。一種是使用Vue全局API,另一種是使用Vue實例上的$set方法。無論哪種方式,它們都可以實現(xiàn)完全相同的效果。我們可以在Vue實例的data屬性中將任何變量聲明為響應式,包括對象和數(shù)組。然而,如果我們需要在對象或數(shù)組中添加或刪除屬性,則需要在其他幾個函數(shù)中使用Vue.set或Vue.delete,以確保這些更改也是響應式的。
// 可響應的對象聲明 var myObject = Vue.observable({}) // 添加屬性項 Vue.set(myObject, '屬性', '值') // 刪除屬性項 Vue.delete(myObject, '屬性')
當我們需要使用Vue.set或Vue.delete方法時,需要遵循一些規(guī)則。我們不能直接操作Vue實例上的data屬性中的屬性項,也不能使用類似以下方法的技巧直接操作它們:
app.data.user.roles.push('admin')
如果我們這樣做,屬性項會失去響應式,這意味著我們無法在更改后立即更新視圖。操作state中的屬性項的正確方法如下所示:
var roles = app.data.user.roles.concat('admin') app.data.user.roles = roles
為了確保新屬性是響應式添加到對象中,我們需要使用Vue.set方法。為了使刪除的屬性是響應式的,我們應該使用Vue.delete方法。Vue.set和Vue.delete本質(zhì)上是對Vue響應系統(tǒng)進行了小的修改,以確保特定屬性被正確地更新。
我們只需要記住一件事,那就是在使用Vue的響應式系統(tǒng)時,我們需要經(jīng)常使用Vue.set和Vue.delete以確保更新行為能夠正確地響應。同時,我們也不應直接更改state中的屬性項,而是應該使用合適的方法進行更改,并且需要注意更新方法是否是響應式的。