更新時(shí)間:2021-10-25 來(lái)源:黑馬程序員 瀏覽量:
watch 偵聽(tīng)器允許開(kāi)發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對(duì)數(shù)據(jù)的變化做特定的操作。例如,監(jiān)視用戶名的變化并發(fā) 起請(qǐng)求,判斷用戶名是否可用。
watch 偵聽(tīng)器的基本語(yǔ)法
開(kāi)發(fā)者需要在 watch 節(jié)點(diǎn)下,定義自己的偵聽(tīng)器。實(shí)例代碼如下:
export default { data() { return { username: ''} }, watch: { //監(jiān)聽(tīng)username的值的變化, //形參列表中,第一個(gè)值是"變化后的新值”,第二個(gè)值是“變化之前的舊值” username(newVal,oldval) { console.log(newVal,oldVal) }, }, }
import axios from 'axios' export default { data() { return { username: '' } }, watch:{ async username(newVal, oldVal) { const { data: res } = await axios.get(`https://www.escook.cn/api/finduser/${newNal}`) console.log(res) }, }, }
immediate 選項(xiàng)
默認(rèn)情況下,組件在初次加載完畢后不會(huì)調(diào)用 watch 偵聽(tīng)器。如果想讓 watch 偵聽(tīng)器立即被調(diào)用,則需要使 用
immediate 選項(xiàng)。實(shí)例代碼如下:
watch: { // 1.監(jiān)聽(tīng)username值的變化 username: { // 2. handler屬性是固定寫(xiě)法:當(dāng)username變化是,調(diào)用handler async handler(newVal, oldVal) { const { data: res } = await axios.get( `https://ww.escook.cn/api/finduser/${newVal} `) console.log(res)}, }, //3.表示組件加載完畢后立即調(diào)用一次當(dāng)前的 watch偵聽(tīng)器 immediate: true11 }, },
deep 選項(xiàng)
data() { return { info: { username: ' admin' }, // info 中包含username 屬性1 } }, watch: { info: { //直接監(jiān)聽(tīng)info對(duì)象的變化 async handler (newVal, oldVal) { const { data: res } = await axios . get(、https:/ /www . escook. cn/ api/ finduser /${newVal . username}、) console. log(res) deep: true //需要使用deep 選項(xiàng),否則username值的變化無(wú)法被監(jiān)聽(tīng)到 }, },
監(jiān)聽(tīng)對(duì)象單個(gè)屬性的變化
如果只想監(jiān)聽(tīng)對(duì)象中單個(gè)屬性的變化,則可以按照如下的方式定義 watch 偵聽(tīng)器:
data() { return { info: { username: 'admin ', password: "' },//info中包含username屬性 } }, watch: { `info.username ' : {//只想監(jiān)聽(tīng)info.username屬性值的變化 async handler(newVal,oldval) { const { data: res } = await axios.get( `https: / /ww.escook.cn/api/finduser /${newal}` ) console.log(res) }, }, },
計(jì)算屬性 vs 偵聽(tīng)器
計(jì)算屬性和偵聽(tīng)器側(cè)重的應(yīng)用場(chǎng)景不同:
計(jì)算屬性側(cè)重于監(jiān)聽(tīng)多個(gè)值的變化,最終計(jì)算并返回一個(gè)新值
偵聽(tīng)器側(cè)重于監(jiān)聽(tīng)單個(gè)數(shù)據(jù)的變化,最終執(zhí)行特定的業(yè)務(wù)處理,不需要有任何返回值。
猜你喜歡:
JavaScript中怎樣創(chuàng)建Date對(duì)象?
servlet事件監(jiān)聽(tīng)器工作步驟介紹
Vue3中Proxy實(shí)現(xiàn)數(shù)據(jù)監(jiān)聽(tīng)的優(yōu)勢(shì)?