Vue学习之实例生命周期

Vue学习之实例生命周期Vue学习之实例生命周期

大家好,又见面了,我是你们的朋友全栈君。

通过前面的介绍我们知道使用Vue的时候我们都必须创建一个Vue实例对象,如下

var vm = new Vue({...})

那么这个Vue实例的生命周期是怎么样的呢?本文我们就来详细的介绍下

在这里插入图片描述

此图为Vue官方给出的生命周期图,可先大概浏览下,如果不懂先不管,继续往下看。

Vue实例生命周期

上图是官方给出的生命周期的流程图。我们一一来介绍下生命周期中各个方法的具体作用,为了便于理解将这些方法分为了三类,分别如下:
创建期间的生命周期函数

 方法           | 说明                                                     
 ------------ | ------------------------------------------------------- 
 beforeCreate | 第一个生命周期方法,表示实例被创建出来之前会被调用 ,此时,还没有初始化好 data 和 methods 属性
 created      | 实例已经在内存中创建完成,此时 data 和 methods 已经创建完成,此时还没有开始 编译模板     
 beforeMount  | 此时已经完成了模板的编译,但是还没有挂载到页面中                               
 mounted      | 此时,已经将编译好的模板,挂载到了页面指定的容器中显示                            

运行期间的生命周期函数

 方法           | 说明                                                               
 ------------ | ----------------------------------------------------------------- 
 beforeUpdate | 状态更新之前执行此函数, 此时 data 中的状态值是最新的,但是界面上显示的 数据还是旧的,因为此时还没有开始重新渲染DOM节点
 updated      | 实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!     

销毁期间的生命周期函数

 方法            | 说明                                                          
 ------------- | ------------------------------------------------------------ 
 beforeDestory | 实例销毁之前调用。在这一步,实例仍然完全可用。                                     
 destoryed     | Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

beforeCreate

首先我们来看下beforeCreate这个方法,这个方法是生命周期的第一个方法,此时Vue实例中的 data 和 methods的内容都还没有被加载如下:

基础页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./lib/vue-2.4.0.js"></script>
</head>
<body>
    <div id="app">
    </div>
    <script >
        var vm = new Vue({
            el: "#app",
            data: {
                msg: 'ok'
            },
            methods: {
                show: function(){
                    console.log("show 方法执行了...")
                }
            }
        })
    </script>
</body>
</html>

然后我们来看下 beforeCreate方法的效果

在这里插入图片描述

在这里插入图片描述

通过页面 控制台 可以看到 data中的数据和 methods中的方法都没有被初始化好。

created

接下来看下 created 方法,该方法是在Vue实例创建完成后被调用用的,且 data和methods 中的都被初始化好了,我们来测试下。

在这里插入图片描述

效果

在这里插入图片描述

beforeMount

beforeMount 执行的时候 已经完成了模板的编译,但是还没有挂载到页面中,我们通过案例来演示下。

在这里插入图片描述

效果

在这里插入图片描述

通过效果可以看出 beforeMount 方法执行的时候 内存的中的数据已经被改变了,但是页面中的数据还没有被渲染。

mounted

mounted方法执行的时候已经将编译好的模板,挂载到了页面指定的容器中显示。

在这里插入图片描述
效果

在这里插入图片描述

通过效果也能看出 mounted 方法执行的时候,内存和页面的数据都已经更新了。
注意: mounted 是 实例创建期间的最后一个生命周期函数,当执行完 mounted 就表示,实例已经被完全创建好了,此时,如果没有其它操作的话,这个实例,就静静的躺在我们的内存中,一动不动.

beforeUpdate

接下来的是运行中的两个方法,beforeUpdate 方法,状态更新之前执行此函数, 此时 data 中的状态值是最新的,但是界面上显示的 数据还是旧的,因为此时还没有开始重新渲染DOM节点。

在这里插入图片描述

在这里插入图片描述

通过效果我们可以看到,当beforeUpdate方法执行的时候,内存的数据被更新了,但是此时 页面中的数据还没有被更新。

updated

实例更新完毕之后调用此函数,此时 data 中的状态值 和 界面上显示的数据,都已经完成了更新,界面已经被重新渲染好了!

在这里插入图片描述
效果

在这里插入图片描述

通过效果可以看到,当 updated方法执行的时候,内存和页面中的数据都已经被更新了!

beforeDestory

beforeDestory 效果不太好演示,实例销毁之前调用。在这一步,实例仍然完全可用,大家记住这个即可

destoryed

同样该方法也不好演示,该方法执行的时候,实例已经不可使用了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106492.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月23日 上午7:00
下一篇 2022年4月23日 上午7:00


相关推荐

  • 软件设计实战:基于Java的俄罗斯方块游戏【完整版】

    软件设计实战:基于Java的俄罗斯方块游戏【完整版】大家好 今天用 Java 编程实现一个 GUI 界面的经典俄罗斯方块游戏 以下是完整的开发思路 供大家学习交流 效果展示目录一 效果展示 1 游戏界面 2 游戏结束二 项目介绍 1 项目背景 2 总体需求 游戏逻辑 游戏过程 其它功能三 代码展示 1 主类和窗口设计 2 子类和方法实现四 项目总结一 效果展示 1 游戏界面 2 游戏结束二 项目介绍 1 项目背景 俄罗斯方块 是一个经典的游戏 在游戏中 由小方块组成

    2026年3月20日
    2
  • java fgc_记一次频繁FGC的简单排查

    java fgc_记一次频繁FGC的简单排查简书占小狼转载请注明原创出处,谢谢!如果读完觉得有收获的话,欢迎点赞加关注周末愉快,今天有时间记录一下上周遇到的一个问题,学习的脚步不能放慢,也不敢放慢。存在问题在线上环境进行服务压测,压测完成后,cpu使用率居高不下,很是费解,按理说已经没有压测请求了,这时消耗cpu资源的只有GC线程了,可以通过jstat命令查看一下JVM的GC情况,然后就碰到了诡异的GC问题。jstat命令jstat[…

    2022年6月19日
    30
  • startActivityForResult被标记为弃用后,如何优雅的启动Activity?

    startActivityForResult被标记为弃用后,如何优雅的启动Activity?startActivityForResult标记为弃用后,如何优雅的启动Activity?ActivityResultAPI已经出来有一段时间了,但是还是有很多朋友对这个API感到使用不便或疑惑,今天尽量用一篇简短的文章简述下registerForActivityResult的使用方法。

    2022年7月11日
    18
  • RPC原理简述

    RPC原理简述RPC RemoteProced 远程过程调用 它是一种通过网络从远程计算机程序上请求服务 而不需要了解底层网络技术的思想 RPC 是一种技术思想而非一种规范或协议 常见 RPC 技术和框架有 应用级的服务框架 阿里的 Dubbo Dubbox GooglegRPC SpringBoot SpringCloud 远程通信协议 RMI Socket SOAP HTTPXML REST HTTPJSON 通信框架 MINA 和 Netty 目前流行的开源 RP

    2026年3月19日
    2
  • windows下cmd查看端口占用情况[通俗易懂]

    windows下cmd查看端口占用情况[通俗易懂]查看端口占用情况进入cmd输入netstat-ano可以列出所有端口占用情况如果只是找特定端口号,输入netstat-ano|findstr“8082”,其中8082为端口号,对应PID为16040继续输入tasklist|findstr“16040”或者到任务管理器-进程查找…

    2022年5月19日
    49
  • 什么是关系型数据库和非关系型数据库_关系型数据库和非关系型区别

    什么是关系型数据库和非关系型数据库_关系型数据库和非关系型区别关系型数据库又称为关系型数据库管理系统(RDBMS),它是利用数据概念实现对数据处理的算法,达到对数据及其快速的增删改查操作。既然被称为关系型数据库,那么它的关系在哪里体现呢?举一个例子吧。比如

    2022年8月1日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号