浅谈vue生命周期共有几个阶段?分别是什么?

一共8个阶段

1、beforeCreate(创建前)

2、created(创建后)

3、beforeMount(载入前)

4、mounted(载入后)

5、beforeUpdate(更新前)

6、updated(更新后)

7、beforeDestroy(销毁前)

8、destroyed(销毁后)

vue第一次页面加载会触发哪几个钩子函数?

beforeCreate、created、beforeMount、mounted

DOM 渲染在哪个周期中就已经完成?

mounted

补充知识:记录一次vue数据不同步的排查

今天我遇到了一个vue异步获取数据后视图没有更新的问题,排查了很久很久,最后才发现自己踩在了一个自己万万没有想到的坑上,所以记录一下。

常见的解决方案

关于vue数据不同步的排查已经有很多类似的博客了,一般而言,原因有一下几点:

数据没有设置成功

设置的数据不是响应式的

设置的数据和视图上的变量不是同一个,可能设置错了变量

既然写到类似话题,我也罗列一下相关的解决方案:

使用this.$set(),

可以尝试类似this.data=JSON.parse(JSON.stringify(data))去排查是不是数据劫持的问题。

这个我一个同事遇到过一次,他发现他的变量里面部分属性没有设置get/set(就是没有被vue监听到,所以无法响应式),原因大概是他在原变量上加了新属性,但是没有被vue监听到。这是一个很有迷惑性的例子,大家可以看看下面的代码:

这里其实是希望属性b可以被监听到的,所以尝试重新给this.data赋值,但是很遗憾,const data的引用和this.data是同一个,this.data = data并不能实现变量的覆盖(因为vue只有变量和之前不同才会对变量里面的所有属性做劫持,同一个引用,vue不会对新属性进行监听)

// 例子
// 假设已经有一个data
{
 data(){
 return {
  data:[{a:1}]
 }
 },
 created(){
 /* 在这里其实我们是希望将变量覆盖的 */
 const data = this.data
 data[0].b = 1
 this.data = data
 }
}

可以看大以下输出,可以看到a属性是有get和set的,即他们已经是响应式的了,但是b却没有get/set。使用this.data=JSON.parse(JSON.stringify(data))的原理实际上就是为了创建一个新的对象重新赋值。

如果还是不行,要仔细检查变量有没有设置成功,可以通过vue的Devtools工具查看,或者直接输出到控制台里面查看。有可能是this等的指向不对或者是拼写错误导致变量赋值失败

还要看看视图里面的变量和你所希望更新的变量是不是同一个,会不会是视图里面的变量写错了

其他的方法还包括:重启以下浏览器,看看是不是浏览器本身异常了等。

接下来,就是我个人的比较独特的问题了,如果你还没有解决,或者好奇我遇到的是一个怎样的问题,你也可以往下读。

问题描述

在chrome浏览器上开发vue项目,结果突然发现异步获取数据后视图没有更新。

排查

这个问题很奇怪,因为之前在公司的时候,代码明明是没有问题的,当时我以为可能是自己不小心改了什么代码,出bug了。当然我心里一点都不慌,数据没有更新嘛,一般原因有以下几点:

数据没有设置成功

设置的数据不是响应式的

设置的数据和视图上的变量不是同一个,可能设置错了变量

结果!!!竟然不是这些原因,我通过vue的Devtools工具查看,发现数据正确设置了,而且是响应式的,可以动态更新。我不放心,又通过debugger打断点,并输出了相应的data到控制台上,结果确认我所希望使用的变量确实已经被vue进行了劫持(vue2的响应式其实就是通过Object.defineProperty对数据进行监听)

我随便mock了一个数据截图如下:如果一个变量属性是响应式的,那它应该会多出了下图中框住的get/set。

由此我确认了我的数据是响应式的,我又再三确认了视图的变量没有问题。这时,我开始慌了,感觉自己可能掉进了一个不好排查的坑里面出不来了。果然,我尝试了各种办法,却始终无法解决这个问题。期间我也试了各种各样的手段去搜索,始终一无所获。

直到我试着在360浏览器上打开这个页面,发现页面的数据竟然可以动态刷新!!!这时我反应过来,难道是浏览器的兼容问题,或者是浏览器本身异常?

我又试着重启chrome浏览器,发现还是不行。

难道真的是兼容问题吗?但是没有理由的呀,之前在公司明明是正常的,难道还和浏览器版本有关系?这时我开始想这个数据和普通的数据有什么不同,一个明显的不同是这个数据嵌套比较深?不会吧,数据嵌套太深会导致数据无法同步的吗?

说实话,我纠结了很久,最后是真的无意间发现了真相:

真相

导致我数据无法同步的真凶竟然是Google 翻译这个插件。。。

真相是这样的,我对页面头部写了<html lang="en">结果浏览器插件就帮我对页面进行了翻译,当然我的页面本身就是中文,我并没有看出异常。但是这个时候的页面已经是翻译的页面了,我dom的变化这个翻译的页面是不会同步的。所以就导致了我所看到的数据没有刷新的问题。

发现真相的时候我的内心是崩溃的,搞了这么就原因竟然是这个。

以上这篇浅谈vue生命周期共有几个阶段?分别是什么?就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 深入理解Vue父子组件生命周期执行顺序及钩子函数

    先附一张官网上的vue实例的生命周期图,每个Vue实例在被创建的时候都需要经过一系列的初始化过程,例如需要设置数据监听,编译模板,将实例挂载到DOM并在数据变化时更新DOM等.同时在这个过程中也会运行一些叫做生命周期钩子的函数(回调函数),这给了用户在不同阶段添加自己代码的机会. 1.vue的生命周期图 在vue实例的整个生命周期的各个阶段,会提供不同的钩子函数以供我们进行不同的操作.先列出vue官网上对各个钩子函数的详细解析. 生命周期钩子 生命周期钩子 详细 beforeCreate 在实例

  • 深入理解Vue生命周期、手动挂载及挂载子组件

    本文介绍了Vue生命周期和手动挂载,分享给大家,具体如下: 1.vue的生命周期: 2.$mount()手动挂载 当Vue实例没有el属性时,则该实例尚没有挂载到某个dom中: 假如需要延迟挂载,可以在之后手动调用vm.$mount()方法来挂载. 例如: 方法一: <div id="app"> {{name}} </div> <button onclick="test()">挂载</button> <scrip

  • 解决Vue中的生命周期beforeDestory不触发的问题

    分享一句很有用的经验: 给router-view加了个keep-alive导致组件缓存了,所以不会触发beforeDestory和destoryed 结束! 补充知识:vuex actions正确使用vue-resource的方式( Error in mounted hook: "TypeError: Cannot read property 'get' of u) 场景 . SPA中 使用vuex初始化一项数据,在vuex的actions中需要使用vue-resource 使用的方式是 act

  • 浅谈vue生命周期共有几个阶段?分别是什么?

    一共8个阶段 1.beforeCreate(创建前) 2.created(创建后) 3.beforeMount(载入前) 4.mounted(载入后) 5.beforeUpdate(更新前) 6.updated(更新后) 7.beforeDestroy(销毁前) 8.destroyed(销毁后) vue第一次页面加载会触发哪几个钩子函数? beforeCreate.created.beforeMount.mounted DOM 渲染在哪个周期中就已经完成? mounted 补充知识:记录一次vu

  • 浅谈angular4生命周期钩子

    理解 Angular提供了生命周期钩子,把这些关键生命时刻暴露出来,赋予我们在它们发生时采取行动的能力.可以将钩子函数理解为在合适的时候做合适的事情. 钩子函数 ng4主要提供了8个钩子函数: 1.ngOnchanges @input属性(输入属性)发生变化时,会调用.非此属性,不会调用. 当输入属性为对象时,当对象的属性值发生变化时,不会调用,当对象的引用变化时会触发. 先于ngOnInit调用. 2.ngOnInit 只执行一次,dom操作可放在其中.(最常用) 3.NgDocheck 每次

  • 浅谈Java生命周期管理机制

    先扯再说 最近一直在研究某个国产开源的MySQL数据库中间件,拉下其最新版的代码到eclipse后,启动起来,然后做各种测试和代码追踪:用完想要关闭它时,拉出它的STOP类想要运行时,发现这个类里赫然只写以下几行代码,于是我感觉瞬间受到了很多伤害. public static void main(String[] args) { System.out.println(new Date() + ",server shutdown!"); } 这个中间件启动和运行的时候,开启了监听,启动着

  • 浅谈Vue.js 1.x 和 2.x 实例的生命周期

    在Vue.js中,在实例化Vue之前,它们都是以HTML的文本形式存在文本编辑器中.当实例化后将经历创建.编译.销毁三个主要阶段. 以下是Vue.js 1.x 实例的生命周期图示: Vue.js 1.x 的生命周期钩子 1. init 在实例开始初始化时同步调用.此时数据观测.事件和Watcher都尚未初始化. 2. created 在实例化创建之后同步调用.此时实例已经结束解析选项,已建立:数据绑定.计算属性.方法.Watcher/事件回调,但是还没有开始DOM编译,$el还不存在. 3. b

  • 浅谈Vuex注入Vue生命周期的过程

    这篇文章是[前端词典]系列文章的第 13 篇文章,接下的 9 篇我会围绕着 Vue 展开,希望这 9 篇文章可以使大家加深对 Vue 的了解.当然这些文章的前提是默认你对 Vue 有一定的基础.如果一点基础都没有,建议先看官方文档. 第一篇文章我会结合 Vue 和 Vuex 的部分源码,来说明 Vuex 注入 Vue 生命周期的过程. 说到源码,其实没有想象的那么难.也和我们平时写业务代码差不多,都是方法的调用.但是源码的调用树会复杂很多. 为何使用 Vuex 使用 Vue 我们就不可避免的会遇

  • 浅谈Vue 函数式组件的使用技巧

    什么是函数式组件 没有管理任何状态,也没有监听任何传递给它的状态,也没有生命周期方法,它只是一个接受一些 prop 的函数.简单来说是 一个无状态和无实例的组件 基本写法: Vue.component('my-component', { functional: true, // Props 是可选的 props: { // ... }, // 为了弥补缺少的实例 // 提供第二个参数作为上下文 render: function(createElement, context) { // ... }

  • 浅谈vue中$bus的使用和涉及到的问题

    Hello大家周末好,最近项目比较忙所以没有及时的更新抱歉,今天给大家讲一vue.bus.使用过的都知道$bus是兄弟之间相互传值的项目中说实话用的地方不算多但是也会用到(每一个领域都是会有坑的呀). 1:创建$bus文件 创建一个文件内容如下: import Vue from 'vue' export default new Vue(); 2:引入$bus main.js: import Bus from './views/bus/bus'; Vue.prototype.$bus = Bus;

  • 浅谈Vue父子组件和非父子组件传值问题

    本文介绍了浅谈Vue父子组件和非父子组件传值问题,分享给大家,具体如下: 1.如何创建组件 1.新建一个组件,如:在goods文件夹下新建goodsList.vue <template> <div class='tmpl'> goodsList组件 </div> </template> <style> </style> <script> export default { data() { return{} }, creat

  • 浅谈Vue.js

    vue.js的总体评价"简单却不失优雅,小巧而不乏大匠" Vue.js简介 Vue.js的作者为Evan You(尤雨溪),任职于Google Creative Lab,虽然Vue是一个个人项目,但在发展前景上个人认为绝不输于Google的AngularJs,下面我会将Vue与Angular(Angular 1.0+版本)做一些简单的比较. Vue的主要特点就和它官网(http://cn.vuejs.org/)所介绍的那样: (1) 简洁 (2) 轻量 (3)快速 (4) 数据驱动 (

  • 详解Vue生命周期的示例

    一 vue的生命周期如下图所示(很清晰) 二 vue生命周期的栗子 注意触发vue的created事件以后,this便指向vue实例,这点很重要 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>vue生命周期</title> <script src="../js/vue.js"></script> &

随机推荐

其他