热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MVVM框架(二)生命周期

一、Vue生命周期图解:这张图是官方给出的,大家可能都看过。其中我们重点讲述以下几个钩子函数:beforeCreate--createdbeforeMount--mounted

一、Vue 生命周期图解:

技术分享图片

  这张图是官方给出的,大家可能都看过。其中我们重点讲述以下几个钩子函数:

  beforeCreate  -->   created

  beforeMount   -->  mounted

  beforeUpdate -->  updated

  beforeDesctroy -->  destroyed

二、生命周期研究:

  对于执行顺序和什么时候执行,看上面图基本有个理解。下面我们结合代码去看看钩子函数的执行。


DOCTYPE html>
<html>
<head>
<title>钩子函数title>
<meta charset="utf-8">
<script src="http://cdn.bootcss.com/vue/2.1.10/vue.js">script>
<body>
<div id="app">
<p>{{ message }}p>
<input type="button" @click="change" value="更新数据" />
<input type="button" @click="destroy" value="销毁" />
div>
<script type="text/Javascript">
var vm = new Vue({
el:
#app,
data: {
message :
"Welcome Vue"
},
methods:{
change() {
this.message = Datura is me;
},
destroy() {
vm.$destroy();
}
},
beforeCreate:
function () {
console.group(
beforeCreate 创建前状态===============》);
console.log(
"%c%s", "color:red","el : " + this.$el); //undefined
console.log("%c%s", "color:red","data : " + this.$data); //undefined
console.log("%c%s", "color:red","message: " + this.message);//undefined
},
created:
function () {
console.group(
created 创建完毕状态===============》);
console.log(
"%c%s", "color:red","el : " + this.$el); //undefined
console.log("%c%s", "color:green","data : " + this.$data); //[object Object] => 已被初始化
console.log("%c%s", "color:green","message: " + this.message); //Welcome Vue => 已被初始化
},
beforeMount:
function () {
console.group(
beforeMount 挂载前状态===============》);
console.log(
"%c%s", "color:green","el : " + (this.$el)); //已被初始化
console.log(this.$el); // 当前挂在的元素
console.log("%c%s", "color:green","data : " + this.$data); //已被初始化
console.log("%c%s", "color:green","message: " + this.message); //已被初始化
},
mounted:
function () {
console.group(
mounted 挂载结束状态===============》);
console.log(
"%c%s", "color:green","el : " + this.$el); //已被初始化
console.log(this.$el);
console.log(
"%c%s", "color:green","data : " + this.$data); //已被初始化
console.log("%c%s", "color:green","message: " + this.message); //已被初始化
},
beforeUpdate:
function () {
alert(
"更新前状态");
console.group(
beforeUpdate 更新前状态===============》); //这里指的是页面渲染新数据之前
console.log("%c%s", "color:green","el : " + this.$el);
console.log(
this.$el);
console.log(
"%c%s", "color:green","data : " + this.$data);
console.log(
"%c%s", "color:green","message: " + this.message);
alert(
"更新前状态2");
},
updated:
function () {
console.group(
updated 更新完成状态===============》);
console.log(
"%c%s", "color:green","el : " + this.$el);
console.log(
this.$el);
console.log(
"%c%s", "color:green","data : " + this.$data);
console.log(
"%c%s", "color:green","message: " + this.message);
},
beforeDestroy:
function () {
console.group(
beforeDestroy 销毁前状态===============》);
console.log(
"%c%s", "color:red","el : " + this.$el);
console.log(
this.$el);
console.log(
"%c%s", "color:red","data : " + this.$data);
console.log(
"%c%s", "color:red","message: " + this.message);
},
destroyed:
function () {
console.group(
destroyed 销毁完成状态===============》);
console.log(
"%c%s", "color:red","el : " + this.$el);
console.log(
this.$el);
console.log(
"%c%s", "color:red","data : " + this.$data);
console.log(
"%c%s", "color:red","message: " + this.message)
}
})
script>
body>
html>

1、create 和 mounted

  beforeCreate:   el 和 data 并未初始化

  created: 完成了data 数据的初始化,el没有

  beforeMount:完成了 el 和 data 初始化

  mounted :完成挂载

  通过代码结果我们还能发现el 中  

{{ message }}

没变,这里就是应用的 Virtual DOM(虚拟Dom)技术,先把坑占住了。到后面mounted挂载的时候再把值渲染进去。

2、update

  我们单击页面中的“更新数据”按钮,将数据更新。下面就能看到data里的值被修改后,将会触发update的操作。

  ps:   注意beforeUpdate是指view层的数据变化前,不是data中的数据改变前触发。因为Vue是数据驱动的。注意观察弹窗就容易发现。  

3、destory

  销毁完成后,我们再重新改变message的值,vue不再对此动作进行响应了。但是原先生成的dom元素还存在,可以这么理解,

执行了destroy操作,后续就不再受vue控制了。因为这个Vue实例已经不存在了。

  我们单击页面中的“销毁”按钮,将指定的Vue实例销毁。

三、生命周期总结:

  beforecreate : 举个栗子:可以在这加个loading事件

  created :在这结束loading,还做一些初始化,实现函数自执行

  mounted : 在这发起后端请求,拿回数据,配合路由钩子做一些事情

  beforeDestory: 你确认删除XX吗?

  destoryed :当前组件已被删除,清空相关内容


推荐阅读
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了一种解析GRE报文长度的方法,通过分析GRE报文头中的标志位来计算报文长度。具体实现步骤包括获取GRE报文头指针、提取标志位、计算报文长度等。该方法可以帮助用户准确地获取GRE报文的长度信息。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
author-avatar
许琼博762375
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有