vue3中watch如何使用,与watchEffect不同及联系是怎样
Admin 2022-07-12 群英技术资讯 565 次浏览
选项式API中,watch 使用
watch:{ mood(curVal,preVal){ console.log('cur',curVal);//最新值 console.log('pre',preVal);//修改之前的值 } }
在 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
也可以监听多个属性值,此时传入的数据变成数组形式,配置项保持不变。
示例2:监听多个属性
watch([mood,target],([curMood,curTarget],[preMood,preTarget])=>{ console.log('curMood',curMood); console.log('preMood',preMood); console.log('curTarget',curTarget); console.log('preTarget',preTarget); },{ //配置项 })
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
也是一个帧听器,是一个副作用函数。它会监听引用数据类型的所有属性,不需要具体到某个属性,一旦运行就会立即监听,组件卸载的时候会停止监听。
示例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
监听函数可以添加配置项,也可以配置为空,配置项为空的情况下,
watch的特点为:
watch 的配置项可以补充watch特点上的不足,可以配置的有:
immediate
:配置watch属性是否立即执行,值为 true 时,一旦运行就会立即执行,值为false
时,保持惰性。deep
:配置 watch
是否深度监听,值为 true 时,可以监听对象所有属性,值为 false 时保持更加具体特性,必须指定到具体的属性上。watchEffect 副作用函数它的特点分别为:
watch
比较难理解。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>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文给大家分享用纯JavaScript+CSS怎样做页面滚动的动画的内容,让元素根据滚动位置实现动画效果比较流行,除了本文的方法也可以用第第三方插件或库来实现,废话不多说,下面直接看代码。
用JS怎样做鼠标经过表格变色的效果?也就是鼠标经过表格的某行时,这行变色显示的效果,这样的好处的就是一目了然看到所选的信息,小编觉得比较有用,因此分享给大家做个参考,感兴趣的朋友就继续往下看吧。
这篇文章给大家分享的是JS中所有字符串转换小写的方法,小编觉得挺实用的,因此分享给大家做个参考,本文使用了toLowerCase()和toLocaleUpperCase()这两个方法,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
useState 通过在函数组件里调用它来给组件添加一些内部 state,React 会在重复渲染时保留这个 state,接下来通过一个示例来看看怎么使用 useState吧
目录小引“类”设计模式举个例子:“原型”设计模式小结小引JavaScript 技能持有者一定有问过这个问题:JavaScript 是面向对象语言吗?你期望得到的答案应该为:“是” 或 “不是”。但是可惜,你得不到这样简单的答案!你大概了解一通之后,你会被告知:JavaScript 不是纯粹的面向对象语言!wtf!为什么
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008