vue实战问题1:vue组件beforeUpdate和updated生命周期钩子不执行

        前段时间遇到的一个问题,项目是由支付宝小程序移植过来的vue项目,将didUpdate更换成了updated,跑起来后发现updated生命周期钩子没有执行。

小程序didUpdate

        组件通信使用的就是普通的父子组件的传值,当时以为是父组件上的数据没有更新,所以导致updated没有执行,不过后来发现父组件的值改变了,但是updated没有执行。找了下官方文档,发现文档中提到了这个坑。


vue官网updated

        updated可能并不会执行,最好的还是使用计算属性或者用watch监听数据变化

watch监听

        以为差不多这样就可以了,后来随着测试的加深,一般监听时是不能监听到对象属性值的变化的,发现如果监听的是Object类型的复杂数据类型的话,这样写是无法监听key和value的变化的,需要对Object类型进行深层监听


深层监听

这样的话,基本上就解决了vue组件beforeUpdate和updated生命周期钩子不执行的问题

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 使用Vue在日常开发中会频繁接触和使用生命周期,在官方文档中是这么解释生命周期的: 每个 Vue 实例在被创...
    心_c2a2阅读 2,287评论 1 8
  • 一:什么是闭包?闭包的用处? (1)闭包就是能够读取其他函数内部变量的函数。在本质上,闭包就 是将函数内部和函数外...
    xuguibin阅读 9,724评论 1 52
  • vue概述 在官方文档中,有一句话对Vue的定位说的很明确:Vue.js 的核心是一个允许采用简洁的模板语法来声明...
    li4065阅读 7,270评论 0 25
  • VUE介绍 Vue的特点构建用户界面,只关注View层简单易学,简洁、轻量、快速渐进式框架 框架VS库库,是一封装...
    多多酱_DuoDuo_阅读 2,742评论 1 17
  • 不想要工程的Info.plist文件或误删之后,新添加一个plist文件作为Info.plist文件时,工程会报一...
    冰land阅读 482评论 0 0