Vue3学习——computed、watch、watchEffect

这篇具有很好参考价值的文章主要介绍了Vue3学习——computed、watch、watchEffect。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

computed

  • 与Vue2.x中computed配置功能一致
  • 写法
import {computed} from 'vue'

setup(){
  ...
  //计算属性——简写
    let fullName = computed(()=>{
      return person.firstName + '-' + person.lastName
    })

    //计算属性——完整
    let fullName = computed({
      get()
        return person.firstName + '-' + person.lastName
      },

      set(value){
        const nameArr = value.split('-')
        person.firstName = nameArr[0]
        person.lastName = nameArr[1]
      }
    })
}

watch

  • 注意
    • 监视reactive定义的响应式数据时:oldValue无法正确获取、强制开启了深度监视(deep配置失效)。
    • 监视reactive定义的响应式数据中的某个属性时:deep配置有效。
情况一:监视ref定义的响应式数据
  • 监视ref定义的对象,改变某一个属性时,newValue和oldValue是同一个值;
  • 若改变整个对象newValue和oldValue不一样;
	 watch(sum, (newValue, oldValue) => {
	   console.log('sum变化了', newValue, oldValue)
	 }, {immediate: true})

情况二:监视多个ref定义的响应式数据(写成数组格式)

	watch([sum, msg], (newValue, oldValue) => {
	   console.log('sum或msg变化了', newValue, oldValue)
	 })

情况三:监视reactive定义的响应式数据,deep默认开启,且关不掉

	 watch(person, (newValue, oldValue) => {
 	     console.log('person变化了', newValue, oldValue)
  	  }, {immediate: true, deep: false}) //此处的deep配置不再奏效

情况四:监视reactive定义的响应式数据中某个属性

  • 可以监视整体改变,也可以监视某个属性改变
  • 监视的属性不是【对象类型】,需写成函数
  • 监视的属性是【对象类型】,可直接编,也可使用函数,推荐使用函数并添加deep属性
    (因为直接写person,无法监听到整个对象的改变;deep是为了深层监听)
    watch(() => person.job, (newValue, oldValue) => {
      console.log('person的job变化了', newValue, oldValue)
    }, {immediate: true, deep: true})

情况五:监视reactive定义的响应式数据中某些属性

    watch([() => person.job, () => person.name], (newValue, oldValue) => {
      console.log('person的job变化了', newValue, oldValue)
    }, {immediate: true, deep: true})

特殊情况

    watch(() => person.job, (newValue, oldValue) => {
      console.log('person的job变化了', newValue, oldValue)
    }, {deep: true}) //此处由于监视的是reactive素定义的对象中的某个属性,所以deep配置有效

停止监视

    const stopWatch =  watch(sum, (newValue, oldValue) => {
      console.log('sum变化了', newValue, oldValue)
      if (sum > 10) {
        stopWatch() // 停止监视
      }
    })

watchEffect

  • watch的套路:既要指明监视的属性,也要指明监视的回调。

  • watchEffect的套路:不用指明监视的哪个属性,监视的回调中用到哪个属性,那就监视哪个属性。

  • watchEffect有点像computed:

  • 但computed注重的计算出来的值(回调函数的返回值),所以必须要写返回值。而watchEffect更注重的是过程(回调函数的函数体),所以不用写返回值。文章来源地址https://www.toymoban.com/news/detail-836124.html


// watchEffect所指定的回调中用到的数据只要发生变化,则直接重新执行回调。初始化也会执行一次

watchEffect(()=>{
    const x1 = sum.value
    const x2 = person.age
    console.log('watchEffect配置的回调执行了')
})

到了这里,关于Vue3学习——computed、watch、watchEffect的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vue3中watch与watchEffect的区别

    给大家打一个比喻 watch:教导主任叫老师看张三和李四是否在睡觉 watchEffect:教导主任叫老师看班上有谁在睡觉,在睡觉的就报告 1.都能监听响应式数据的变化,不同的是监听数据变化的方式不同 2.watch:要明确指出监视的数据 3.watchEffect:不用明确的指出监视的数据(函数中

    2024年02月21日
    浏览(34)
  • vue3的watchEffect和watch其他参数

    目录 1、watchEffect基本使用 2、watch 与 watchEffect的异同 3、watch其他参数使用 1、watchEffect基本使用 1 回调函数立即调用 2 回调函数依赖的数据都会被监控 3 深度监控 2 、 watch 与 watchEffect的异同 1、 相同点 :都可以对数据进行侦听 2、 不同点 :watchEffect回调函数立即调用、对回调

    2024年01月24日
    浏览(32)
  • Vue3watch 和 watchEffect

    计算属性是通过声明性的计算衍生值,然而有些情况,我们需要在状态变化时执行一些\\\"副作用\\\",例如更改DOM,或是根据异步操作的结果去修改另一处的状态。 一般来说,computed主要是涉及计算某些值的时候使用, watch(Effect)函数主要是监听某个状态,当某个状态改变时才会触

    2024年02月20日
    浏览(29)
  • Vue3的watchEffect的妙用,与watch的区别

    在Vue3中,引入了Composition API,其中的 watchEffect() 函数是一个非常强大和灵活的工具,用于处理响应式数据的变化,使得项目更加弹性和灵活。它与 watch 有所不同,本文将介绍 watchEffect() 的定义、特点、与 watch 的区别以及使用时的注意事项。 watchEffect() 函数用于创建一个自动

    2024年02月16日
    浏览(33)
  • vue全家桶进阶之路32:Vue3 WatchEffect和watch 监听

    在 Vue 3 中, watchEffect 是一个用于监听响应式数据变化的 API。它可以在函数内部自动跟踪数据的依赖,并在依赖变化时重新运行函数。 watchEffect  的作用以及各个参数的功能讲解: watchEffect(effect: (onInvalidate: InvalidateCbRegistrator) = void | (() = void) | Promisevoid, options?: WatchEffectOptio

    2023年04月17日
    浏览(66)
  • Vue3.0 watch和watchEffect监听器:VCA

    在项目中,有时候检测一个变量的值是否反升了变化。通常使用的watch或者使用低效的循环判断。 在次vue中给我们设置了深度监测数据繁盛变化的方法。 1.vue中提供了在watch监听时设置deep:true 就可以实现对对象的深度监听; 2.immediate:true,代表watch里面声明了之后会立马执行han

    2024年02月06日
    浏览(35)
  • Vue3的computed和watch

    目录 1、computed 2、computed完整写法  3、watch 4、watch监听对象具体属性 5、watch 监听reactive数据 1、computed 基于现有的数据计算出新的数据 2、computed完整写法   3、watch 1 . 侦听一个数据 第一个参数:监听的数据 第二个回调函数 2.侦听多个数据 第一个参数监听的数据构成的数组

    2024年01月24日
    浏览(30)
  • vue3 computed 和 watch 的差异

    🙂博主:锅盖哒 🙂文章核心: vue3 computed 和 watch 的差异 目录 前言 用法 computed watch 代码 理解 高质量的使用 Vue.js作为一种现代化的前端框架,提供了丰富的特性来帮助开发者构建高效和响应式的用户界面。在这其中, computed 和 watch 是两个非常重要的选项,它们都用于处理

    2024年02月08日
    浏览(35)
  • Vue3的computed计算属性和watch监视(四)

    监视【ref】定义的【基本数据】类型 监视【ref】定义的【对象类型】数据 监视【reactive】定义的【对象类型】数据  与 场景二 不同的是,newVal和oldVal是一样的,表明通过Object.assign重新赋值的时候,并不是生成一个新的对象,而是新的值覆盖了旧值 监视【ref】或者【reactiv

    2024年02月21日
    浏览(36)
  • 【vue3】关于watch与computed的用法看这个就ok

    😉博主:初映CY的前说(前端领域) ,📒本文核心:watch()与computed的使用【vue2中watch|computed概念详解】,本文将介绍在vue3中怎么使用这两者技能 【前言】vue2当中有这两个技能,那么vue3中的watch与computed是怎么用呢? 注意点:对 reactive 自身的修改则不会触发监听。 一定得注意不

    2023年04月10日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包