人工智能

Vue 3 学习笔记—Watch 、WatchEffect 新用法

时间:2010-12-5 17:23:32  作者:域名   来源:数据库  查看:  评论:0
内容摘要:选项式API与之前写法相同,本篇文章主要通过 Options API 和 Composition API 对比 watch 的使用方法,让您快速掌握 vue3 中 watch 新用法。建议收藏!一、w

选项式API与之前写法相同,学习笔t新本篇文章主要通过 Options API 和 Composition API 对比 watch 的用法使用方法,让您快速掌握 vue3 中 watch 新用法。学习笔t新建议收藏!

一、用法watch 新用法

选项式API中,学习笔t新watch 使用

watch:{   mood(curVal,用法preVal){    console.log(cur,curVal);//最新值   console.log(pre,preVal);//修改之前的值  } } 

1.1、watch 使用语法

在 Composition API 中,学习笔t新使用 watch 时,用法必须先引入。学习笔t新使用语法为:

import {  watch } from "vue" watch(  name ,用法  ( curVal , preVal )=>{  //业务处理  },  options ) 

 共有三个参数,分别为:

name :需要帧听的学习笔t新属性 (curVal,preVal)=>{ //业务处理 } 箭头函数,是用法监听到的最新值和本次修改之前的值,此处进行逻辑处理。学习笔t新 options :配置项,用法对监听器的学习笔t新配置,如:是否深度监听。

页面刚进入的时候并不会执行,值发生改变的时候,才会打印出当前最新值和修改之前的值。

示例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 时保持更加具体特性,必须指定到具体的云南idc服务商属性上。

3.3、watchEffect 特点

watchEffect 副作用函数它的特点分别为:

非惰性:一旦运行就会立即执行。

更加抽象:使用时不需要具体指定监听的谁,回调函数内直接使用就可以。相比watch比较难理解。

不可访问之前的值:只能访问当前最新的值,访问不到修改之前的值。

3.4、watch 与 watchEffect 联系

watch 的前两个特点与 watchEffect 的两个特点刚好相反,watch 通过配置项可以修改成带有 watchEffect 特点。

示例5:watch 监听对象

<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> 
copyright © 2025 powered by 益强资讯全景  滇ICP备2023006006号-31sitemap