返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue3.0中的watch侦听器实例详解
  • 576
分享到

vue3.0中的watch侦听器实例详解

2024-04-02 19:04:59 576人浏览 安东尼
摘要

目录前言 侦听器和计算属性的区别vue3如何使用watch呢? 基本使用监听多个响应式数据侦听Reactive定义的响应式数据 监听reactive定义的响应式数据的某一个属性配置选

前言

虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过watch选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。

侦听器和计算属性的区别

计算属性里不可以做异步操作,侦听器可以做异步操作,相当于计算属性的升级版

 

vue3如何使用watch呢?

基本使用


<template>
  <h1>watch侦听器页面</h1>
  <p>普通侦听数据:{{ num }}</p>
  <button @click="butFn">点击</button>
</template>

script


import { ref, watch } from 'vue'
// 记得用到什么就要导入什么vue3的新特性,按需调用
 setup() {
 
    const num = ref(0)
    // watch(要侦听的数据,回调函数)
    watch(num, (v1, v2) => {
      // v1 是改变以后的新值
      // v2 是改变前的值
      console.log(v1, v2)
      // 要点:侦听普通函数可以获取修改前后的值,被侦听的数据必须是响应式的
    })
    
    // 单机事件
      const butFn = () => {
      num.value++
    }
    
     return { butFn, num }
}

监听多个响应式数据


    const num = ref(0)
    const num2 = ref(20)
    
    watch([num, num2], (v1, v2) => {
      // 存入的结果是一个数组,结果返回的也是一个已数组格式的结果
      // v1是最新结果的数组
      // v2是旧数据的数组
      console.log('v1', v1, 'v2', v2)
    // 总结:可以得到更新前后的值,侦听的结果也是数组数据顺序一致
    })

侦听reactive定义的响应式数据


	const obj = reactive({
      msg: '奇奇怪怪可可爱爱'
    })
    
   watch(obj, () => {
      // 只能获取到最新的值
      console.log(obj.msg)
    })

总结:如果侦听对象,那么侦听器的回调函数的两个参数是一样的结果,表示最新的对象数据,此时也可以直接读取被侦听的对象,那么得到的值也是最新的。

监听reactive定义的响应式数据的某一个属性


	const obj = reactive({
      msg: '奇奇怪怪可可爱爱'
    })
    
	watch(() => obj.msg,(v1, v2) => {
        // v1 就是被监听数据的最新值
        // v2 就是被监听数据的原有值
        console.log(v1, v2)
        // 总结:如果侦听对象中当个属性,需要使用箭头函数的方式
        // 侦听更少的数据有利于提高性能
      }
    )

配置选项用法


   const obj = reactive({
      msg: {
        info: 'ooo'
      }
    })
   watch(() => obj.msg,(v1, v2) => {
        console.log(v1, v2)
      },
      {
        // 首次渲染组件就触发一次
        immediate: true,
        // 开启深度监听,对象里面的数据如果发生变化也会被侦听到
        // 如果监听的数据是一个比较长的表达式,那么需要用一个函数的方式
        // 但是写成函数形式之后,里层的数据变化不到,所以需要添加deep选项
        deep: true
      }
    )

总结

到此这篇关于vue3.0中watch侦听器实例详解的文章就介绍到这了,更多相关vue3.0 watch侦听器内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue3.0中的watch侦听器实例详解

本文链接: https://lsjlt.com/news/137597.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作