亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue 3 中watch 和watchEffect 的新用法

 更新時(shí)間:2021年11月27日 09:52:07   作者:前端人  
本篇文章主要通過 Options API 和 Composition API 對比 watch 的使用方法,讓大家快速掌握 vue3 中 watch 新用法,需要的朋友可以參考一下哦,希望對大家有所幫助

一、watch 新用法

選項(xiàng)式API中,watch 使用

watch:{

 mood(curVal,preVal){

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

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

 }

}

1.1、watch 使用語法

Composition API 中,使用 watch 時(shí),必須先引入。

使用語法為:

import { watch } from "vue"

watch(

 name ,

 ( curVal , preVal )=>{ //業(yè)務(wù)處理  },

 options

)

共有三個(gè)參數(shù),分別為:

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

頁面剛進(jìn)入的時(shí)候并不會(huì)執(zhí)行,值發(fā)生改變的時(shí)候,才會(huì)打印出當(dāng)前最新值和修改之前的值。

示例1:監(jiān)聽一個(gè)數(shù)據(jù)

import { ref , watch } from "vue"

export default{

 setup(){

  const mood = ref("")

  //幀聽器

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

   console.log('cur',curVal);

   console.log('pre',preVal);

  },{

   //配置項(xiàng)

  })

  return{

   mood

  }

 }

}

watch 也可以監(jiān)聽多個(gè)屬性值,此時(shí)傳入的數(shù)據(jù)變成數(shù)組形式,配置項(xiàng)保持不變。

1.2、watch 監(jiān)聽多個(gè)屬性值

示例2:監(jiān)聽多個(gè)屬性

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

 console.log('curMood',curMood);

 console.log('preMood',preMood);

 console.log('curTarget',curTarget);

 console.log('preTarget',preTarget);

},{

  //配置項(xiàng)

}) 

1.3、watch 監(jiān)聽引用數(shù)據(jù)類型

watch 監(jiān)聽引用數(shù)據(jù)類型時(shí),如果只監(jiān)聽其中某個(gè)屬性時(shí),

使用語法如下:

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

 //幀聽引用數(shù)據(jù)類型的某個(gè)屬性

},{

 //配置項(xiàng)

})

第一個(gè)參數(shù),回調(diào)函數(shù)返回的是需要幀聽對象的屬性。后邊的參數(shù)與上邊的一致。

示例3:幀聽對象某個(gè)屬性

<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>

如果我們試著把屬性去掉,直接監(jiān)聽整個(gè)對象,發(fā)現(xiàn)watch好像失效了。此時(shí)我們就需要引入 watchEffect。

二、watchEffect

watchEffect 也是一個(gè)幀聽器,是一個(gè)副作用函數(shù)。它會(huì)監(jiān)聽引用數(shù)據(jù)類型的所有屬性,不需要具體到某個(gè)屬性,一旦運(yùn)行就會(huì)立即監(jiān)聽,組件卸載的時(shí)候會(huì)停止監(jiān)聽。

示例4:監(jiān)聽對象

<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 參數(shù)只有一個(gè)回調(diào)函數(shù)。此時(shí)刷新頁面進(jìn)入,watchEffect 就會(huì)打印結(jié)果。

三、watch 與 watchEffect 區(qū)別和聯(lián)系

watch watchEffect 都是監(jiān)聽器,那么它們之間有什么關(guān)系呢?

3.1、watch特點(diǎn)

watch 監(jiān)聽函數(shù)可以添加配置項(xiàng),也可以配置為空,配置項(xiàng)為空的情況下,

watch的特點(diǎn)為:

  • 有惰性:運(yùn)行的時(shí)候,不會(huì)立即執(zhí)行。
  • 更加具體:需要添加監(jiān)聽的屬性。
  • 可以訪問屬性之前的值:回調(diào)函數(shù)內(nèi)會(huì)返回最新值和修改之前的值。
  • 可配置:可以添加配置項(xiàng)。

3.2、watch 配置項(xiàng)

watch 的配置項(xiàng)可以補(bǔ)充watch特點(diǎn)上的不足,可以配置的有:

  • immediate:配置watch屬性是否立即執(zhí)行,值為 true 時(shí),一旦運(yùn)行就會(huì)立即執(zhí)行,值為false時(shí),保持惰性。
  • deep:配置 watch 是否深度監(jiān)聽,值為 true 時(shí),可以監(jiān)聽對象所有屬性,值為 false 時(shí)保持更加具體特性,必須指定到具體的屬性上。

3.3、watchEffect 特點(diǎn)

watchEffect 副作用函數(shù)它的特點(diǎn)分別為:

  • 非惰性:一旦運(yùn)行就會(huì)立即執(zhí)行。
  • 更加抽象:使用時(shí)不需要具體指定監(jiān)聽的誰,回調(diào)函數(shù)內(nèi)直接使用就可以。相比watch比較難理解。
  • 不可訪問之前的值:只能訪問當(dāng)前最新的值,訪問不到修改之前的值。

3.4、watch 與 watchEffect 聯(lián)系

watch 的前兩個(gè)特點(diǎn)與 watchEffect 的兩個(gè)特點(diǎn)剛好相反,watch 通過配置項(xiàng)可以修改成帶有 watchEffect 特點(diǎn)。

示例5watch 監(jiān)聽對象

<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>

到此這篇關(guān)于 vue 3 中watch 和watchEffect 的新用法的文章就介紹到這了,更多相關(guān) vue 3 中watch 和watchEffect 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • VUE-ElementUI 自定義Loading圖操作

    VUE-ElementUI 自定義Loading圖操作

    這篇文章主要介紹了VUE-ElementUI 自定義Loading圖操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue 項(xiàng)目打包時(shí)樣式及背景圖片路徑找不到的解決方式

    vue 項(xiàng)目打包時(shí)樣式及背景圖片路徑找不到的解決方式

    今天小編就為大家分享一篇vue 項(xiàng)目打包時(shí)樣式及背景圖片路徑找不到的解決方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue實(shí)現(xiàn)登錄功能

    vue實(shí)現(xiàn)登錄功能

    這篇文章主要介紹了vue實(shí)現(xiàn)登錄功能的步驟,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • VUE中使用MUI方法

    VUE中使用MUI方法

    在本篇文章里小編給大家分享了關(guān)于VUE中使用MUI方法和步驟,有需要的朋友們可以學(xué)習(xí)參考下。
    2019-02-02
  • 詳解vue父子組件間傳值(props)

    詳解vue父子組件間傳值(props)

    本篇文章主要介紹了詳解vue父子組件間傳值(props),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • nginx如何配置vue項(xiàng)目history的路由模式(非根目錄)

    nginx如何配置vue項(xiàng)目history的路由模式(非根目錄)

    這篇文章主要介紹了nginx如何配置vue項(xiàng)目history的路由模式(非根目錄),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue+element-ui+ajax實(shí)現(xiàn)一個(gè)表格的實(shí)例

    vue+element-ui+ajax實(shí)現(xiàn)一個(gè)表格的實(shí)例

    下面小編就為大家分享一篇vue+element-ui+ajax實(shí)現(xiàn)一個(gè)表格的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue Cli 3項(xiàng)目使用融云IM實(shí)現(xiàn)聊天功能的方法

    Vue Cli 3項(xiàng)目使用融云IM實(shí)現(xiàn)聊天功能的方法

    這篇文章主要介紹了Vue Cli 3項(xiàng)目 使用融云IM實(shí)現(xiàn)聊天功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • JavaScript獲取echart曲線上任意點(diǎn)位的值詳解

    JavaScript獲取echart曲線上任意點(diǎn)位的值詳解

    這篇文章主要為大家介紹了JavaScript獲取echart曲線上任意點(diǎn)位的值詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Vue常用指令v-if與v-show的區(qū)別淺析

    Vue常用指令v-if與v-show的區(qū)別淺析

    v-if和v-show的區(qū)別是前端面試中常問的基礎(chǔ)知識(shí)點(diǎn),v-if、v-show顧名思義就是用來判斷視圖層展示效果的,下面這篇文章主要給大家介紹了關(guān)于Vue常用指令v-if與v-show區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-10-10

最新評論