成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Vue 3 學習筆記—Watch 、WatchEffect 新用法

開發 前端
選項式API與之前寫法相同,本篇文章主要通過 Options API 和 Composition API 對比 watch 的使用方法,讓您快速掌握 vue3 中 watch 新用法。

[[438961]]

選項式API與之前寫法相同,本篇文章主要通過 Options API 和 Composition API 對比 watch 的使用方法,讓您快速掌握 vue3 中 watch 新用法。建議收藏!

一、watch 新用法

選項式API中,watch 使用

  1. watch:{ 
  2.  mood(curVal,preVal){ 
  3.   console.log('cur',curVal);//最新值 
  4.   console.log('pre',preVal);//修改之前的值 
  5.  } 

1.1、watch 使用語法

在 Composition API 中,使用 watch 時,必須先引入。使用語法為:

  1. import { watch } from "vue" 
  2. watch( 
  3.  name , 
  4.  ( curVal , preVal )=>{ //業務處理  }, 
  5.  options 

 共有三個參數,分別為:

  • name :需要幀聽的屬性
  • (curVal,preVal)=>{ //業務處理 } 箭頭函數,是監聽到的最新值和本次修改之前的值,此處進行邏輯處理。
  • options :配置項,對監聽器的配置,如:是否深度監聽。

頁面剛進入的時候并不會執行,值發生改變的時候,才會打印出當前最新值和修改之前的值。

示例1:監聽一個數據

  1. import { ref , watch } from "vue" 
  2. export default
  3.  setup(){ 
  4.   const mood = ref(""
  5.   //幀聽器 
  6.   watch(mood,(curVal,preVal)=>{ 
  7.    console.log('cur',curVal); 
  8.    console.log('pre',preVal); 
  9.   },{ 
  10.    //配置項 
  11.   }) 
  12.   return
  13.    mood 
  14.   } 
  15.  } 

 watch 也可以監聽多個屬性值,此時傳入的數據變成數組形式,配置項保持不變。

1.2、watch 監聽多個屬性值

示例2:監聽多個屬性

  1. watch([mood,target],([curMood,curTarget],[preMood,preTarget])=>{ 
  2.  console.log('curMood',curMood); 
  3.  console.log('preMood',preMood); 
  4.  console.log('curTarget',curTarget); 
  5.  console.log('preTarget',preTarget); 
  6. },{ 
  7.   //配置項 
  8. }) 

1.3、watch 監聽引用數據類型

watch 監聽引用數據類型時,如果只監聽其中某個屬性時,使用語法如:

  1. watch(()=>obj.name,(curValue,preValue)=>{ 
  2.  //幀聽引用數據類型的某個屬性 
  3. },{ 
  4.  //配置項 
  5. }) 

 第一個參數,回調函數返回的是需要幀聽對象的屬性。后邊的參數與上邊的一致。

示例3:幀聽對象某個屬性

  1. <template> 
  2.  <div> 
  3.   {{obj}} 
  4.   <input type="text" v-model="obj.name"
  5.  </div> 
  6. </template> 
  7. <script> 
  8. import { ref , reactive , watch } from "vue" 
  9. export default
  10.  setup(){ 
  11.   const obj = reactive({ name:'qq',sex:'女' }) 
  12.   watch(()=>obj.name,(cur,pre)=>{ 
  13.    console.log('cur',cur); 
  14.   },{ }) 
  15.   return
  16.    obj 
  17.   } 
  18.  } 
  19. </script> 

 如果我們試著把屬性去掉,直接監聽整個對象,發現watch好像失效了。此時我們就需要引入 watchEffect。

二、watchEffect

watchEffect 也是一個幀聽器,是一個副作用函數。它會監聽引用數據類型的所有屬性,不需要具體到某個屬性,一旦運行就會立即監聽,組件卸載的時候會停止監聽。

示例4:監聽對象

  1. <template> 
  2.   <div> 
  3.     {{obj}} 
  4.     <input type="text" v-model="obj.name"
  5.     <input type="text" v-model="obj.sex"
  6.   </div> 
  7. </template> 
  8. <script> 
  9. import {   reactive  , watchEffect } from "vue" 
  10. export default
  11.   setup(){ 
  12.     let obj = reactive({ name:'qq',sex:'女'}) 
  13.     watchEffect(() => { 
  14.       console.log('name',obj.name); 
  15.       console.log('sex' , obj.sex); 
  16.     }) 
  17.     return
  18.       obj 
  19.     } 
  20.   } 
  21. </script> 

 watchEffect 參數只有一個回調函數。此時刷新頁面進入,watchEffect 就會打印結果。

三、watch 與 watchEffect 區別和聯系

watch 與 watchEffect 都是監聽器,那么它們之間有什么關系呢?

3.1、watch特點

watch 監聽函數可以添加配置項,也可以配置為空,配置項為空的情況下,watch的特點為:

有惰性:運行的時候,不會立即執行。

更加具體:需要添加監聽的屬性。

可以訪問屬性之前的值:回調函數內會返回最新值和修改之前的值。

可配置:可以添加配置項。

3.2、watch 配置項

watch 的配置項可以補充watch特點上的不足,可以配置的有:

immediate:配置watch屬性是否立即執行,值為 true 時,一旦運行就會立即執行,值為false時,保持惰性。

deep:配置 watch 是否深度監聽,值為 true 時,可以監聽對象所有屬性,值為 false 時保持更加具體特性,必須指定到具體的屬性上。

3.3、watchEffect 特點

watchEffect 副作用函數它的特點分別為:

非惰性:一旦運行就會立即執行。

更加抽象:使用時不需要具體指定監聽的誰,回調函數內直接使用就可以。相比watch比較難理解。

不可訪問之前的值:只能訪問當前最新的值,訪問不到修改之前的值。

3.4、watch 與 watchEffect 聯系

watch 的前兩個特點與 watchEffect 的兩個特點剛好相反,watch 通過配置項可以修改成帶有 watchEffect 特點。

示例5:watch 監聽對象

  1. <template> 
  2.  <div> 
  3.   {{obj}} 
  4.   <input type="text" v-model="obj.name"
  5.  </div> 
  6. </template> 
  7. <script> 
  8. import { ref , reactive , watch } from "vue" 
  9. export default
  10.  setup(){ 
  11.   const obj = reactive({ name:'qq',sex:'女' }) 
  12.   watch(()=>obj,(cur,pre)=>{ 
  13.    console.log('cur',cur); 
  14.   },{  
  15.    immediate:true
  16.    deep:true 
  17.   }) 
  18.   return
  19.    obj 
  20.   } 
  21.  } 
  22. </script> 

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-12-08 09:09:33

Vue 3 Computed Vue2

2022-07-14 08:22:48

Computedvue3

2022-06-09 08:28:27

Vue3watchwatchEffec

2021-12-01 08:11:44

Vue3 插件Vue應用

2023-12-14 08:25:14

WatchVue.js監聽數據

2021-12-09 08:49:14

Vue 3 Provide Inject

2023-11-29 08:49:31

Vue.jsData 函數

2022-09-19 18:49:01

偵聽器異步組件

2021-11-16 08:50:29

Vue3 插件Vue應用

2024-01-04 08:38:21

Vue3API慎用

2021-11-30 08:19:43

Vue3 插件Vue應用

2023-11-28 09:03:59

Vue.jsJavaScript

2021-12-29 07:51:21

Vue3 插件Vue應用

2013-01-08 17:25:49

Android MapSDKMapFragment

2023-11-28 17:49:51

watch?computed?性能

2021-12-02 05:50:35

Vue3 插件Vue應用

2025-06-30 09:46:34

Vue3性能API

2023-12-11 07:34:37

Computed計算屬性Vue3

2025-04-07 08:50:36

2018-06-29 09:52:45

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www.亚洲一区二区 | a视频在线| 亚av在线 | 国产亚洲精品精品国产亚洲综合 | 亚洲激情一区二区 | 成人三级视频 | 亚洲精品美女视频 | 最新日韩在线视频 | 免费在线观看成人 | 欧美日韩国产在线观看 | 日韩欧美三区 | 久久久久久久久国产成人免费 | 久久综合久久综合久久 | 日日夜夜天天 | 久久精品一区 | 亚洲午夜精品久久久久久app | 激情国产视频 | 一区二区三区中文字幕 | 精品国产乱码久久久久久丨区2区 | 日韩中文不卡 | 特级a欧美做爰片毛片 | 国产精品欧美一区二区三区不卡 | 日中文字幕在线 | 亚洲欧美激情精品一区二区 | 蜜桃五月天 | 欧美不卡一区二区三区 | 午夜成人免费视频 | 国产黄色精品在线观看 | 日韩欧美国产一区二区三区 | 亚洲播放一区 | 国产精品亚洲欧美日韩一区在线 | 久久com| 日韩a视频| 久久99国产精品久久99果冻传媒 | a级片www| 国产一级免费视频 | 久热久热 | 亚洲一区二区在线播放 | 午夜精品久久久 | 精品国产一区二区三区免费 | 成人国产精品免费观看 |