vue3的watchEffect和watch其他参数

2024-01-24 01:28

本文主要是介绍vue3的watchEffect和watch其他参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1、watchEffect基本使用

2、watch 与 watchEffect的异同

3、watch其他参数使用


1、watchEffect基本使用

1 回调函数立即调用

2 回调函数依赖的数据都会被监控

3 深度监控

<template><div><button @click="num++">num++</button></div>
</template><script setup>
import { watchEffect,  ref,  reactive } from 'vue'
// watchEffect监控数据
const num =ref(10)
const obj = reactive({name: 'zs',age: 18,boyFriend: {name: 'lisi',age: 19}
})watchEffect(() => {console.log(num.value);console.log(obj.boyFriend.name);
})</script><style lang="scss" scoped></style>

2watch 与 watchEffect的异同

1、 相同点 :都可以对数据进行侦听

2、 不同点 :watchEffect回调函数立即调用、对回调函数依赖的数据隐式监控、默认深度监控

watch 和 watchEffect 都能监听响应式数据的变化,不同的是它们监听数据变化的方式不同。

watch 会明确监听某一个响应数据,而 watchEffect 则是隐式的监听回调函数中响应数据。 watch 在响应数据初始化时是不会执行回调函数的, watchEffect在响应数据初始化时就会立即执行回调函数。

3、watch其他参数使用

watchPostEffect() 是watchEffect() 使用 flush: 'post' 选项时的别名。

onInvalidate副作用清理函数

执行时机:下一次副作用执行前

 

<script setup >import {ref, watch} from 'vue'let sum=ref(0)
let qyz=ref(null)
const sumadd=()=>{sum.value++
}//onInvalidate副作用清理函数
//副作用-发网络请求。开启定时器,控制台输出
watch(sum,(newVal,oldval,onInvalidate)=>{   //数据变了才执行//onInvalidate副作用清理函数console.log('青阳子')console.log('DOM节点',qyz.value.innerHTML)onInvalidate(()=>{//执行时机:下一次副作用执行前console.log(222)})
},{flush:'post'//拿到dom更新后的值
})
</script><template>
<div>hello,world</div>
<div><h2 ref="qyz">{{ sum }}</h2></div>
<button @click="sumadd">sum++</button></template><style scoped></style>

这篇关于vue3的watchEffect和watch其他参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/638131

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指