在Vue中,computed是一個非常有用的屬性,可以根據(jù)data中的值計算出所需的值并進行渲染。除了這一功能,computed還可以用來監(jiān)聽data的變化,一旦data中的值發(fā)生改變,computed中相關(guān)的值也會隨之改變。
為了進一步解釋computed監(jiān)聽的作用,下面我們來看一個實例。假設我們有一個購物車頁面,每個商品都有數(shù)量和單價,計算每個商品的總價需要涉及數(shù)量和單價兩個因素。那么我們就可以使用computed屬性來計算每個商品的總價,代碼如下:
data: { cart: [ { name: 'iPhone X', price: 9999, quantity: 2 }, { name: 'Macbook Pro', price: 14999, quantity: 1 }, ] }, computed: { totalCartPrice: function() { var total = 0; for (var i = 0; i< this.cart.length; i++) { total += this.cart[i].price * this.cart[i].quantity; } return total; } }
以上代碼中,totalCartPrice是我們通過computed計算出來的結(jié)果,當我們添加、刪除或者修改購物車中的某個商品時,totalCartPrice會重新計算,自動更新對應的值。
除了以上實例中直接使用computed監(jiān)聽data中的變化,我們還可以通過watcher來實現(xiàn)這一功能。watcher是Vue中另一種監(jiān)聽數(shù)據(jù)變化的方式,它可以在data改變時執(zhí)行一些特定的操作。
總的來說,使用computed監(jiān)聽data的變化非常方便,可以讓我們不用手動去修改數(shù)據(jù),避免了代碼中的重復操作,使用起來也非常簡單和高效。