Vue基礎(chǔ)之偵聽(tīng)器詳解
vue中什么是偵聽(tīng)器
- 開(kāi)發(fā)中我們?cè)赿ata返回的對(duì)象中定義了數(shù)據(jù),這個(gè)數(shù)據(jù)可以通過(guò)插值語(yǔ)法等方式綁定到templat中。
- 當(dāng)數(shù)據(jù)變化的時(shí)候,template里綁定的數(shù)據(jù)會(huì)自動(dòng)進(jìn)行更新來(lái)顯示最新的數(shù)據(jù)。但是這種變化是在template中自動(dòng)偵聽(tīng)data的值來(lái)進(jìn)行變換的
- 在某些情況下,我們希望在代碼邏輯中監(jiān)聽(tīng)某個(gè)數(shù)據(jù)的變化,這個(gè)時(shí)候就需要用到偵聽(tīng)器watch了
官方定義:Vue 通過(guò) watch 選項(xiàng)提供了一個(gè)更通用的方法,來(lái)響應(yīng)數(shù)據(jù)的變化。當(dāng)需要在數(shù)據(jù)變化時(shí)執(zhí)行異步或開(kāi)銷較大的操作時(shí),這個(gè)方式是最有用的。
一個(gè)對(duì)象,鍵是要偵聽(tīng)的響應(yīng)式 property——包含了 data 或 computed property,而值是對(duì)應(yīng)的回調(diào)函數(shù)。值也可以是方法名,或者包含額外選項(xiàng)的對(duì)象。組件實(shí)例將會(huì)在實(shí)例化時(shí)調(diào)用 $watch(),參閱 $watch,以了解更多關(guān)于 deep、immediate 和 flush 選項(xiàng)的信息
偵聽(tīng)器的用法
選項(xiàng):watch
類型:{ [key: string]: string | Function | Object | Array}
偵聽(tīng)器watch的配置選項(xiàng):
默認(rèn)情況下,watch只是在偵聽(tīng)數(shù)據(jù)的引用變化,對(duì)于數(shù)據(jù)內(nèi)部屬性的變化是不會(huì)做出響應(yīng)的:
這個(gè)時(shí)候我們可以使用一個(gè)選項(xiàng)deep進(jìn)行更深層的偵聽(tīng);另外一個(gè)屬性,是希望一開(kāi)始的就會(huì)立即執(zhí)行一次:這個(gè)時(shí)候我們使用immediate選項(xiàng);這個(gè)時(shí)候無(wú)論后面數(shù)據(jù)是否有變化,偵聽(tīng)的函數(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文檔中沒(méi)有提到的,但是Vue2文檔中有提到的是偵聽(tīng)對(duì)象的屬性:
'info.name': function(newValue, oldValue) { console.log(newValue, oldValue) }
還有另外一種方式就是使用 $watch 的API:
具體$watch可以查看官方的API查看(用的方式比較少):實(shí)例方法 | Vue.js
const app = createApp({ data() { return { a: 1, b: 2, c: { d: 4 }, e: 5, f: 6 } }, watch: { // 偵聽(tīng)頂級(jí) property a(val, oldVal) { console.log(`new: ${val}, old: ${oldVal}`) }, // 字符串方法名 b: 'someMethod', // 該回調(diào)會(huì)在任何被偵聽(tīng)的對(duì)象的 property 改變時(shí)被調(diào)用,不論其被嵌套多深 c: { handler(val, oldVal) { console.log('c changed') }, deep: true }, // 偵聽(tīng)單個(gè)嵌套 property 'c.d': function (val, oldVal) { // do something }, // 該回調(diào)將會(huì)在偵聽(tīng)開(kāi)始之后被立即調(diào)用 e: { handler(val, oldVal) { console.log('e changed') }, immediate: true }, // 你可以傳入回調(diào)數(shù)組,它們會(huì)被逐一調(diào)用 f: [ 'handle1', function handle2(val, oldVal) { console.log('handle2 triggered') }, { handler: function handle3(val, oldVal) { console.log('handle3 triggered') } /* ... */ } ] }, methods: { someMethod() { console.log('b changed') }, handle1() { console.log('handle 1 triggered') } } }) const vm = app.mount('#app') vm.a = 3 // => new: 3, old: 1
vue偵聽(tīng)器-watch
目標(biāo): 可以偵聽(tīng)data/computed屬性值改變
語(yǔ)法:
watch: { "被偵聽(tīng)的屬性名" (newVal, oldVal){ } }
例子代碼:
<template> <div> <input type="text" v-model="name"> </div> </template> <script> export default { data(){ return { name: "" } }, // 目標(biāo): 偵聽(tīng)到name值的改變 /* 語(yǔ)法: 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é): 想要偵聽(tīng)一個(gè)屬性變化, 可使用偵聽(tīng)屬性watch
vue偵聽(tīng)器-深度偵聽(tīng)和立即執(zhí)行
目標(biāo): 可以偵聽(tīng)data/computed屬性值改變
語(yǔ)法:
watch: { "被偵聽(tīng)的屬性名" (newVal, oldVal){ } }
例子代碼:
<template> <div> <input type="text" v-model="user.name"> <input type="text" v-model="user.age"> </div> </template> <script> export default { data(){ return { user: { name: "", age: 0 } } }, // 目標(biāo): 偵聽(tīng)對(duì)象 /* 語(yǔ)法: watch: { 變量名 (newVal, oldVal){ // 變量名對(duì)應(yīng)值改變這里自動(dòng)觸發(fā) }, 變量名: { handler(newVal, oldVal){ }, deep: true, // 深度偵聽(tīng)(對(duì)象里面層的值改變) immediate: true // 立即偵聽(tīng)(網(wǎng)頁(yè)打開(kāi)handler執(zhí)行一次) } } */ watch: { user: { handler(newVal, oldVal){ // user里的對(duì)象 console.log(newVal, oldVal); }, deep: true, immediate: true } } } </script> <style> </style>
小結(jié): immediate立即偵聽(tīng), deep深度偵聽(tīng), handler固定方法觸發(fā)
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
- vue基礎(chǔ)之面包屑和標(biāo)簽tag詳解
- vue基礎(chǔ)之ElementUI表格詳解
- Vue基礎(chǔ)之MVVM,模板語(yǔ)法和數(shù)據(jù)綁定
- vue基礎(chǔ)之使用get、post、jsonp實(shí)現(xiàn)交互功能示例
- vue基礎(chǔ)之事件v-onclick="函數(shù)"用法示例
- vue基礎(chǔ)之data存儲(chǔ)數(shù)據(jù)及v-for循環(huán)用法示例
- 從vue基礎(chǔ)開(kāi)始創(chuàng)建一個(gè)簡(jiǎn)單的增刪改查的實(shí)例代碼(推薦)
- vue快速入門基礎(chǔ)知識(shí)教程
相關(guān)文章
解決vue中axios設(shè)置超時(shí)(超過(guò)5分鐘)沒(méi)反應(yīng)的問(wèn)題
這篇文章主要介紹了解決vue中axios設(shè)置超時(shí)(超過(guò)5分鐘)沒(méi)反應(yīng)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09Vue3+Element?Plus實(shí)現(xiàn)動(dòng)態(tài)標(biāo)簽頁(yè)以及右鍵菜單功能
這篇文章主要給大家介紹了關(guān)于Vue3+Element?Plus實(shí)現(xiàn)動(dòng)態(tài)標(biāo)簽頁(yè)以及右鍵菜單功能的相關(guān)資料,Vue?3和Element?Plus提供了一種簡(jiǎn)單的方法來(lái)實(shí)現(xiàn)側(cè)邊菜單欄與標(biāo)簽頁(yè)之間的聯(lián)動(dòng),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09Vue3超詳細(xì)的ref()用法教程(看這一篇就夠了!)
這篇文章主要給大家介紹了關(guān)于Vue3超詳細(xì)的ref()用法的相關(guān)資料,在Vue3中ref函數(shù)不僅可以用于在組件中獲取DOM元素或子組件的引用,還可以直接訪問(wèn)組件元素本身,需要的朋友可以參考下2023-07-07el-form表單驗(yàn)證的一些實(shí)用方法總結(jié)
表單校驗(yàn)是注冊(cè)環(huán)節(jié)中必不可少的操作,表單校驗(yàn)通過(guò)一定的規(guī)則來(lái)確保用戶提交數(shù)據(jù)的有效性,下面這篇文章主要給大家介紹了關(guān)于el-form表單驗(yàn)證的一些實(shí)用方法,需要的朋友可以參考下2023-01-01詳解用webpack2.0構(gòu)建vue2.0超詳細(xì)精簡(jiǎn)版
本篇文章主要介紹了詳解用webpack2.0構(gòu)建vue2.0超詳細(xì)精簡(jiǎn)版,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04