vue如何解决watch和methods值执行顺序问题

 更新时间:2024年08月07日 09:46:51   作者:帅比九日  
这篇文章主要介绍了vue如何解决watch和methods值执行顺序问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

问题

  • 父组件:
<GroupTransform
            :is-show.sync="selectPeopleDialogVisible"
            @callback="getSelectedPeople"
        ></GroupTransform>
watch: {
        selectGroupRight: {
            handler(val) {
            },
            deep: true,

        },
    },
methods:{
getSelectedPeople(){},
}
  • 子组件:
confirm() {
            this.$emit('input', this.rightGroups);
            this.$emit('callback');
        },

目的是当我们触发子组件的confirm时,先更新该组件绑定的v-model的值触发watch,然后再触发callback事件绑定的方法getSelectedPeople。

但是实际执行结果是先执行了getSelectedPeople,然后再进入了watch。

原因

查询资料后得到以下结论,具体源码和机制暂时不明

(1)页面初始化时: 会执行一次computed,watch初始化时不会执行,methods只有调用的时候才会执行

(2)渲染完成后:

  • 如果不是由点击事件造成的数据变化,执行顺序为:watch——beforeUpdate——computed——updated
  • 如果是由点击事件造成的数据变化,执行顺序为:methods——watch——beforeUpdate——computed——update

继续深究:为什么watcher没有立即执行?

在vue的watcher.js文件源码中,我找到了这么一段

 // options
    if (options) {
      this.deep = !!options.deep
      this.user = !!options.user
      this.lazy = !!options.lazy
      this.sync = !!options.sync
    } else {
      this.deep = this.user = this.lazy = this.sync = false
    }
  ......
 /**
   * Subscriber interface.
   * Will be called when a dependency changes.
   */
  update () {
    /* istanbul ignore else */
    if (this.lazy) {
      this.dirty = true
    } else if (this.sync) {
      this.run()
    } else {
      queueWatcher(this)
    }
  }

可以看到vue的watcher除了我们常用的deep属性可以配置,其实还有一个属性叫做sync,这个属性影响着我们的watcher什么时候执行watcher的回调。

正常情况下不设置sync,依赖数据变动时会触发warcher将其推送进入队列,等到下一个渲染周期的时候触发。

但是$emit触发父组件的自定义事件不会等到下一个周期执行,而是立即执行。

所以代码的效果就变成了先执行callback绑定的父组件getSelectedPeople,再进入watch。

解决方法

如果要程序按照我们最初的想法,先触发watch,在执行methods中的方法,那么只需要在watch中设置sync属性为true即可。

watch: {
        selectGroupRight: {
            handler(val) {},
            deep: true,
            sync: true,
        },
    },

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue Router中Matcher的初始化流程

    Vue Router中Matcher的初始化流程

    这篇文章主要介绍了Vue Router中Matcher的初始化流程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • 在vue3中安装使用bootstrap过程

    在vue3中安装使用bootstrap过程

    这篇文章主要介绍了在vue3中安装使用bootstrap过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue-router路由懒加载和权限控制详解

    vue-router路由懒加载和权限控制详解

    这篇文章主要介绍了vue-router路由懒加载和权限控制的相关资料
    2017-12-12
  • 关于对keep-alive的理解,使用场景以及存在的问题解读

    关于对keep-alive的理解,使用场景以及存在的问题解读

    这篇文章主要介绍了关于对keep-alive的理解,使用场景以及存在的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05
  • 一篇文章搞懂Vue3中如何使用ref获取元素节点

    一篇文章搞懂Vue3中如何使用ref获取元素节点

    过去在Vue2中,我们采用ref来获取标签的信息,用以替代传统 js 中的 DOM 行为,下面这篇文章主要给大家介绍了关于如何通过一篇文章搞懂Vue3中如何使用ref获取元素节点的相关资料,需要的朋友可以参考下
    2022-11-11
  • vue动画—通过钩子函数实现半场动画操作

    vue动画—通过钩子函数实现半场动画操作

    这篇文章主要介绍了vue动画—通过钩子函数实现半场动画操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • mpvue+vant app搭建微信小程序的方法步骤

    mpvue+vant app搭建微信小程序的方法步骤

    这篇文章主要介绍了mpvue+vant app搭建微信小程序的方法步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • 微信小程序Webview与H5通信的思路与实战记录

    微信小程序Webview与H5通信的思路与实战记录

    这篇文章主要介绍了微信小程序Webview与H5通信的思路与实战的相关资料,由于微信小程序与H5之间的通信限制,无法满足业务需求,通过动态改变url的hash值来传递参数,并利用vue-router组件的路由守卫来避免页面刷新,需要的朋友可以参考下
    2025-01-01
  • vue实现循环滚动图片

    vue实现循环滚动图片

    这篇文章主要为大家详细介绍了vue实现循环滚动图片,多图片轮播,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • vue实现弹幕功能

    vue实现弹幕功能

    这篇文章主要介绍了vue实现弹幕功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10

最新评论