亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3中watch和watchEffect怎么使用

發布時間:2021-11-30 19:00:04 來源:億速云 閱讀:363 作者:iii 欄目:開發技術

這篇文章主要講解了“vue3中watch和watchEffect怎么使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vue3中watch和watchEffect怎么使用”吧!

一、watch 新用法

選項式API中,watch 使用

watch:{

 mood(curVal,preVal){

  console.log('cur',curVal);//最新值

  console.log('pre',preVal);//修改之前的值

 }

}

1.1、watch 使用語法

Composition API 中,使用 watch 時,必須先引入。

使用語法為:

import { watch } from "vue"

watch(

 name ,

 ( curVal , preVal )=>{ //業務處理  },

 options

)

共有三個參數,分別為:

  • name :需要幀聽的屬性

  • (curVal,preVal)=>{ //業務處理 } 箭頭函數,是監聽到的最新值和本次修改之前的值,此處進行邏輯處理。

  • options :配置項,對監聽器的配置,如:是否深度監聽。

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

示例1:監聽一個數據

import { ref , watch } from "vue"

export default{

 setup(){

  const mood = ref("")

  //幀聽器

  watch(mood,(curVal,preVal)=>{

   console.log('cur',curVal);

   console.log('pre',preVal);

  },{

   //配置項

  })

  return{

   mood

  }

 }

}

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

1.2、watch 監聽多個屬性值

示例2:監聽多個屬性

watch([mood,target],([curMood,curTarget],[preMood,preTarget])=>{

 console.log('curMood',curMood);

 console.log('preMood',preMood);

 console.log('curTarget',curTarget);

 console.log('preTarget',preTarget);

},{

  //配置項

})

1.3、watch 監聽引用數據類型

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

使用語法如下:

watch(()=>obj.name,(curValue,preValue)=>{

 //幀聽引用數據類型的某個屬性

},{

 //配置項

})

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

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

<template>

 <div>

  {{obj}}

  <input type="text" v-model="obj.name">

 </div>

</template>

<script>

import { ref , reactive , watch } from "vue"

export default{

 setup(){

  const obj = reactive({ name:'qq',sex:'女' })

  watch(()=>obj.name,(cur,pre)=>{

   console.log('cur',cur);

  },{ })

  return{

   obj

  }

 }

}

</script>

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

二、watchEffect

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

示例4:監聽對象

<template>

  <div>

    {{obj}}

    <input type="text" v-model="obj.name">

    <input type="text" v-model="obj.sex">

  </div>

</template>

<script>

import {   reactive  , watchEffect } from "vue"

export default{

  setup(){

    let obj = reactive({ name:'qq',sex:'女'})

    watchEffect(() => {

      console.log('name',obj.name);

      console.log('sex' , obj.sex);

    })

    return{

      obj

    }

  }

}

</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 特點。

示例5watch 監聽對象

<template>

 <div>

  {{obj}}

  <input type="text" v-model="obj.name">

 </div>

</template>

<script>

import { ref , reactive , watch } from "vue"

export default{

 setup(){

  const obj = reactive({ name:'qq',sex:'女' })

  watch(()=>obj,(cur,pre)=>{

   console.log('cur',cur);

  },{ 

   immediate:true,

   deep:true

  })

  return{

   obj

  }

 }

}

</script>

感謝各位的閱讀,以上就是“vue3中watch和watchEffect怎么使用”的內容了,經過本文的學習后,相信大家對vue3中watch和watchEffect怎么使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩留县| 喀什市| 娱乐| 佛冈县| 鄂伦春自治旗| 新密市| 姚安县| 富宁县| 禹城市| 民丰县| 万全县| 泰顺县| 舞阳县| 泾川县| 大同县| 丹阳市| 阳江市| 利辛县| 哈尔滨市| 离岛区| 股票| 荥阳市| 临漳县| 平南县| 杭锦后旗| 龙陵县| 筠连县| 青阳县| 若尔盖县| 延津县| 曲靖市| 吴川市| 本溪市| 迁安市| 海门市| 荆州市| 襄城县| 兴山县| 莱州市| 象州县| 衡山县|