在Vue中,watch是實(shí)時(shí)監(jiān)聽一個(gè)變量,并在其值發(fā)生改變時(shí)執(zhí)行特定操作的功能。Vue中的watch功能非常強(qiáng)大,可以監(jiān)聽單個(gè)變量或者多個(gè)變量,并且還支持深度監(jiān)聽。它對(duì)于實(shí)現(xiàn)一些數(shù)據(jù)的同步處理非常有用。
Vue中watch的用法十分簡(jiǎn)單,只需要在Vue實(shí)例內(nèi)添加watch屬性即可。watch屬性以對(duì)象的形式存在,對(duì)象的屬性名為要監(jiān)聽的變量名,屬性值為回調(diào)函數(shù)。
watch:{ name:function(newVal,oldVal){ //回調(diào)函數(shù) console.log(newVal,oldVal); } }
在上述代碼中,我們添加了一個(gè)watch屬性,監(jiān)聽了一個(gè)名為name的變量,在name變量的值發(fā)生改變時(shí),控制臺(tái)將輸出新值和舊值。回調(diào)函數(shù)的第一個(gè)參數(shù)表示新值,第二個(gè)參數(shù)表示舊值。
除了監(jiān)聽單個(gè)變量外,watch還可以監(jiān)聽多個(gè)變量。
watch:{ name:function(newVal,oldVal){ console.log(newVal,oldVal); }, age:function(newVal,oldVal){ console.log(newVal,oldVal); } }
在上述代碼中,我們添加了一個(gè)watch屬性,監(jiān)聽了名為name和age的兩個(gè)變量,在這兩個(gè)變量的值發(fā)生改變時(shí),控制臺(tái)將分別輸出新值和舊值。
除了普通的監(jiān)聽外,watch還支持監(jiān)聽對(duì)象內(nèi)部屬性的變化。我們可以使用deep屬性來(lái)告訴watch對(duì)象,需要深度監(jiān)聽對(duì)象內(nèi)部的數(shù)據(jù)。
watch:{ data:{ handler:function(newVal,oldVal){ console.log(newVal,oldVal); }, deep:true } }
在上述代碼中,我們添加了一個(gè)watch屬性,并監(jiān)聽名為data的變量。在data對(duì)象內(nèi)部的任何屬性發(fā)生改變時(shí),控制臺(tái)都將輸出新值和舊值。
watch還支持immediate屬性,該屬性用于定義watch屬性實(shí)例化時(shí)是否立即執(zhí)行回調(diào)函數(shù)。
watch:{ data:{ handler:function(newVal,oldVal){ console.log(newVal,oldVal); }, immediate:true } }
在上述代碼中,我們添加了一個(gè)watch屬性,并監(jiān)聽名為data的變量。immediate屬性為true,因此,在watch屬性實(shí)例化時(shí),將立即執(zhí)行回調(diào)函數(shù)。
總之,watch是Vue的一個(gè)非常強(qiáng)大的功能,它可以實(shí)現(xiàn)多種實(shí)時(shí)監(jiān)聽的功能。掌握watch的用法,可以讓您更加方便地實(shí)現(xiàn)數(shù)據(jù)的同步處理。