首页 > 其他分享 >vue3+watch

vue3+watch

时间:2024-08-19 11:52:30浏览次数:8  
标签:watch 参数 vue3 执行 数据 监听 进行

watch—vue3

是一个惰性,所谓惰性,就是被动的去进行调用,而不是主动的去进行触发,可以通过使用immediate来等进行立即执行调用
如何在初始阶段进行触发呢?
了解到watch中的参数
watch(参数一:监听的数据,参数二:回调函数()=>{编辑代码},参数三:option?用于执行一些配置选项)

参数一:是在setup的语法糖中定义的一个数据,
通过ref进行普通的响应式数据,例如字符串,数字类型等
通过reactive进行复杂数据的响应式数据,例如对象,数组等

通过参数一中的数据进行监听,来判断是否需要触发,

参数二:是来进行一个回到函数,当监听到数据在发生变化 到时候,就会去执行这个回调函数。其中第一个参数是新变化的值,第二个是以前的值,这个是在普通的数据进行变化,当复杂的数据进行变化的时候,可以通过数组的方法进行参数定义,那么在第一个参数是以数组进行展示,并且都是新变化的值,第二个参数是以前的值 ,例如

const a=ref(1)
const b=reactive({a:1111})
watch([a,()=>b.a],([onenew,twonew],[oneold,twoold])=>{
  console.log('新'+onenew,'旧'+oneold)
  console.log('新'+twonew,'旧'+twoold)
},{immediate:true})

参数三:就是我们在上面提到的一些配置的问题

第一个是immediate:是在watch在组件进行创建完成之后立即执行,在以上的代码中使用对象的形式进行使用。
第二个是deep:在默认的情况下,监听一个对象或者是数组进行变化的监听的时候,不会往其内部去监听变化,如果我们想要了解更多的变化,就可以使用deep进行深度监听。
第三个是flush:指的是我们进行回到函数中,应该怎么样去执行。在什么时候去执行。
其中flush的值有:

  • async: 同步下执行代码
  • pre:在数据变化之前执行回调函数
  • post:在数据变化完成之后执行回调函数,但是必须在所以依赖都更新完成之后才可以执行。
const a=ref(1)
const b=reactive({a:1111})
watch([a,()=>b.a],([onenew,twonew],[oneold,twoold])=>{
  console.log('新'+onenew,'旧'+oneold)
  console.log('新'+twonew,'旧'+twoold)
},{flush:'sync'})

进行一个扩展watchEffect:
并不是惰性,非惰性,一旦运行就会立即执行,只能访问到最新的数据,不能访问到旧数据。
watchEffect其实也是一个侦听器,也是一个副作用函数,
但是当我们需要监听一个对象的时候,以及引用数据类型的时候,不需要具体到某一个属性,一旦运行就会立即执行,当卸载的时候就会立即停止。
注意:只是依赖项不需要某一个属性,也不需要参数,但是在进行输出的时候需要具体到某一个属性

//通过触发响应式数据进行触发监听,
const c=reactive({
a: {
  name: 'zhangsan',
  agge: 18
}})
watchEffect(()=>{
  console.log('c中的a的属性值'+c.a.agge)
})

标签:watch,参数,vue3,执行,数据,监听,进行
From: https://blog.csdn.net/wang050128/article/details/141321085

相关文章

  • 【Vue3】准备工作
    系列文章目录第一章准备工作文章目录系列文章目录第一节:Node安装一、nvm二、node:三、npm第二节:VSCode一、下载地址二、概念讲解三、插件安装第三节:VSCode快捷键通用快捷键基础编辑导航查询与替换多行光标操作与选择丰富的语言操作编辑器管理文件管理显示集成终端......
  • Vue3+Axios
    使用Vue3和Axios实现CRUD操作在当今的前端开发中,Vue.js作为一款流行的JavaScript框架,正在被越来越多的开发者所青睐。尤其是Vue3引入了CompositionAPI和更优雅的响应式处理,使得模板编写和状态管理变得更加直观。在这篇博客中,我将带领大家通过一个简单的示例,使用......
  • 卧槽,牛逼!vue3的组件竟然还能“暂停”渲染!
    前言有的时候我们想要从服务端拿到数据后再去渲染一个组件,为了实现这个效果我们目前有几种实现方式:将数据请求放到父组件去做,并且使用v-if控制拿到子组件后才去渲染子组件,然后将数据从父组件通过props传给子组件。在子组件的onMounted中请求数据,并且使用v-if在子组件的temp......
  • 030、Vue3+TypeScript基础,路由中History和HashHistory的区别
    01、index.ts路由代码如下://创建路由并暴露出去import{createRouter,createWebHistory}from'vue-router'importHomefrom'@/view/Home.vue'importAboutfrom'@/view/About.vue'importNewsfrom'@/view/News.vue'constrouter=cr......
  • vue3 - 详细实现内网使用离线百度地图功能,在vue3中无需网络离线使用百度地图相关功能,
    效果图在vue3、nuxt3项目开发中,完成内网离线使用百度地图详细教程,让vue3网站无需网络就能加载百度地图及相关功能,完整的百度地图离线使用及地图瓦片的下载教程、更新教程等,vue3百度地图内网离线使用显示地图及各种功能,无论js/ts语法都可以使用,详解百度地图离线加载机制及整......
  • 029、Vue3+TypeScript基础,路由组件和一般组件的存放位置,以及页面生命周期
    01、main.js代码如下://引入createApp用于创建Vue实例import{createApp}from'vue'//引入App.vue根组件importAppfrom'./App.vue'//引入路由importrouterfrom'./router'constapp=createApp(App);//使用路由app.use(router);//App.vue的根元素id为ap......
  • 028、Vue3+TypeScript基础,使用路由功能实现页面切换效果
    01、在main.js中引入路由并使用路由,代码如下://引入createApp用于创建Vue实例import{createApp}from'vue'//引入App.vue根组件importAppfrom'./App.vue'//引入路由importrouterfrom'./router'constapp=createApp(App);//使用路由app.use(router);//App......
  • 027、Vue3+TypeScript基础,使用自定义hook,把功能计算都放到hook中精简代码
    01、在view中创建myhook文件夹,并创建2个文件。usesDog.ts代码如下:import{onMounted,reactive}from"vue";importaxiosfrom"axios";exportdefaultfunction(){//抓取图片letdogList=reactive(['https://images.dog.ceo/breeds/pembro......
  • 026、Vue3+TypeScript基础,使用async和await来异步读取axios的网络图片
    01、App.vue代码如下:<template><divclass="app"><h2>App.Vue</h2><Person/></div></template><scriptlang="ts"setupname="App">//JS或TSimportPersonfrom'./......
  • Vue3编写一个可以用js调用的组件
    项目开发中基本都会用到组件库,但是设计稿样式和功能不一定和组件库相同,尤其像是消息提示弹窗、确认弹窗,各个项目都有自己的一套风格。如何封装一个自己的弹窗组件,且不需要每个用到弹窗的组件都需要引入这个弹窗组件,然后传参等等这些繁琐的步骤。而只需要使用简单的js就可以直接调......