Vue基礎(chǔ)之偵聽器詳解_第1頁(yè)
Vue基礎(chǔ)之偵聽器詳解_第2頁(yè)
Vue基礎(chǔ)之偵聽器詳解_第3頁(yè)
Vue基礎(chǔ)之偵聽器詳解_第4頁(yè)
Vue基礎(chǔ)之偵聽器詳解_第5頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第Vue基礎(chǔ)之偵聽器詳解目錄vue中什么是偵聽器偵聽器的用法vue偵聽器-watchvue偵聽器-深度偵聽和立即執(zhí)行總結(jié)

vue中什么是偵聽器

開發(fā)中我們?cè)赿ata返回的對(duì)象中定義了數(shù)據(jù),這個(gè)數(shù)據(jù)可以通過插值語(yǔ)法等方式綁定到templat中。

當(dāng)數(shù)據(jù)變化的時(shí)候,template里綁定的數(shù)據(jù)會(huì)自動(dòng)進(jìn)行更新來(lái)顯示最新的數(shù)據(jù)。但是這種變化是在template中自動(dòng)偵聽data的值來(lái)進(jìn)行變換的

在某些情況下,我們希望在代碼邏輯中監(jiān)聽某個(gè)數(shù)據(jù)的變化,這個(gè)時(shí)候就需要用到偵聽器watch了

官方定義:Vue通過watch選項(xiàng)提供了一個(gè)更通用的方法,來(lái)響應(yīng)數(shù)據(jù)的變化。當(dāng)需要在數(shù)據(jù)變化時(shí)執(zhí)行異步或開銷較大的操作時(shí),這個(gè)方式是最有用的。

一個(gè)對(duì)象,鍵是要偵聽的響應(yīng)式property——包含了data或computedproperty,而值是對(duì)應(yīng)的回調(diào)函數(shù)。值也可以是方法名,或者包含額外選項(xiàng)的對(duì)象。組件實(shí)例將會(huì)在實(shí)例化時(shí)調(diào)用$watch(),參閱$watch,以了解更多關(guān)于deep、immediate和flush選項(xiàng)的信息

偵聽器的用法

選項(xiàng):watch

類型:{[key:string]:string|Function|Object|Array}

偵聽器watch的配置選項(xiàng):

默認(rèn)情況下,watch只是在偵聽數(shù)據(jù)的引用變化,對(duì)于數(shù)據(jù)內(nèi)部屬性的變化是不會(huì)做出響應(yīng)的:

這個(gè)時(shí)候我們可以使用一個(gè)選項(xiàng)deep進(jìn)行更深層的偵聽;另外一個(gè)屬性,是希望一開始的就會(huì)立即執(zhí)行一次:這個(gè)時(shí)候我們使用immediate選項(xiàng);這個(gè)時(shí)候無(wú)論后面數(shù)據(jù)是否有變化,偵聽的函數(shù)都會(huì)有限執(zhí)行一次;

data的內(nèi)容:

data(){

return{

info:{

name:'cgj'

watch:{

info:{

handler(newValue,oldValue){

console.log(newValue,oldValue)

deep:true,

immediate:true,

另外一個(gè)是Vue3文檔中沒有提到的,但是Vue2文檔中有提到的是偵聽對(duì)象的屬性:

'':function(newValue,oldValue){

console.log(newValue,oldValue)

還有另外一種方式就是使用$watch的API:

具體$watch可以查看官方的API查看(用的方式比較少):實(shí)例方法|Vue.js

constapp=createApp({

data(){

return{

a:1,

b:2,

c:{

d:4

e:5,

f:6

watch:{

//偵聽頂級(jí)property

a(val,oldVal){

console.log(`new:${val},old:${oldVal}`)

//字符串方法名

b:'someMethod',

//該回調(diào)會(huì)在任何被偵聽的對(duì)象的property改變時(shí)被調(diào)用,不論其被嵌套多深

c:{

handler(val,oldVal){

console.log('cchanged')

deep:true

//偵聽單個(gè)嵌套property

'c.d':function(val,oldVal){

//dosomething

//該回調(diào)將會(huì)在偵聽開始之后被立即調(diào)用

e:{

handler(val,oldVal){

console.log('echanged')

immediate:true

//你可以傳入回調(diào)數(shù)組,它們會(huì)被逐一調(diào)用

f:[

'handle1',

functionhandle2(val,oldVal){

console.log('handle2triggered')

handler:functionhandle3(val,oldVal){

console.log('handle3triggered')

/*...*/

methods:{

someMethod(){

console.log('bchanged')

handle1(){

console.log('handle1triggered')

constvm=app.mount('#app')

vm.a=3//=new:3,old:1

vue偵聽器-watch

目標(biāo):可以偵聽data/computed屬性值改變

語(yǔ)法:

watch:{

"被偵聽的屬性名"(newVal,oldVal){

例子代碼:

template

div

inputtype="text"v-model="name"

/div

/template

script

exportdefault{

data(){

return{

name:""

//目標(biāo):偵聽到name值的改變

watch:{

變量名(newVal,oldVal){

//變量名對(duì)應(yīng)值改變這里自動(dòng)觸發(fā)

watch:{

//newVal:當(dāng)前最新值

//oldVal:上一刻值

name(newVal,oldVal){

console.log(newVal,oldVal);

/script

style

/style

小結(jié):想要偵聽一個(gè)屬性變化,可使用偵聽屬性watch

vue偵聽器-深度偵聽和立即執(zhí)行

目標(biāo):可以偵聽data/computed屬性值改變

語(yǔ)法:

watch:{

"被偵聽的屬性名"(newVal,oldVal){

例子代碼:

template

div

inputtype="text"v-model=""

inputtype="text"v-model="user.age"

/div

/template

script

exportdefault{

data(){

return{

user:{

name:"",

age:0

//目標(biāo):偵聽對(duì)象

watch:{

變量名(newVal,oldVal){

//變量名對(duì)應(yīng)值改變這里自動(dòng)觸發(fā)

變量名:{

handler(newVal,oldVal){

deep:true,//深度偵聽(對(duì)象里面層的值改變)

immediate:true//立即偵聽(網(wǎng)頁(yè)打開handler執(zhí)行一次)

watch:{

user:{

handler(newVal,oldVal){

//user里的對(duì)象

console.log(newVal,oldVal);

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論