热门标签 | 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 :当前组件已被删除,清空相关内容


推荐阅读
  • 本项目通过Python编程实现了一个简单的汇率转换器v1.02。主要内容包括:1. Python的基本语法元素:(1)缩进:用于表示代码的层次结构,是Python中定义程序框架的唯一方式;(2)注释:提供开发者说明信息,不参与实际运行,通常每个代码块添加一个注释;(3)常量和变量:用于存储和操作数据,是程序执行过程中的重要组成部分。此外,项目还涉及了函数定义、用户输入处理和异常捕获等高级特性,以确保程序的健壮性和易用性。 ... [详细]
  • 在 LeetCode 的“有效回文串 II”问题中,给定一个非空字符串 `s`,允许删除最多一个字符。本篇深入解析了如何判断删除一个字符后,字符串是否能成为回文串,并提出了高效的优化算法。通过详细的分析和代码实现,本文提供了多种解决方案,帮助读者更好地理解和应用这一算法。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • IOS Run loop详解
    为什么80%的码农都做不了架构师?转自http:blog.csdn.netztp800201articledetails9240913感谢作者分享Objecti ... [详细]
  • 使用jqTransform插件美化表单
    jqTransform 是由 DFC Engineering 开发的一款 jQuery 插件,专用于美化表单元素,操作简便,能够美化包括输入框、单选按钮、多行文本域、下拉选择框和复选框在内的所有表单元素。 ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ... [详细]
  • poj 3352 Road Construction ... [详细]
  • Spark中使用map或flatMap将DataSet[A]转换为DataSet[B]时Schema变为Binary的问题及解决方案
    本文探讨了在使用Spark的map或flatMap算子将一个数据集转换为另一个数据集时,遇到的Schema变为Binary的问题,并提供了详细的解决方案。 ... [详细]
  • CentOS 7 中 iptables 过滤表实例与 NAT 表应用详解
    在 CentOS 7 系统中,iptables 的过滤表和 NAT 表具有重要的应用价值。本文通过具体实例详细介绍了如何配置 iptables 的过滤表,包括编写脚本文件 `/usr/local/sbin/iptables.sh`,并使用 `iptables -F` 清空现有规则。此外,还深入探讨了 NAT 表的配置方法,帮助读者更好地理解和应用这些网络防火墙技术。 ... [详细]
  • 在使用Eclipse进行调试时,如果遇到未解析的断点(unresolved breakpoint)并显示“未加载符号表,请使用‘file’命令加载目标文件以进行调试”的错误提示,这通常是因为调试器未能正确加载符号表。解决此问题的方法是通过GDB的`file`命令手动加载目标文件,以便调试器能够识别和解析断点。具体操作为在GDB命令行中输入 `(gdb) file `。这一步骤确保了调试环境能够正确访问和解析程序中的符号信息,从而实现有效的调试。 ... [详细]
  • 开发技巧:在Interface Builder中实现UIButton文本居中对齐的方法与步骤
    开发技巧:在Interface Builder中实现UIButton文本居中对齐的方法与步骤 ... [详细]
  • MySQL的查询执行流程涉及多个关键组件,包括连接器、查询缓存、分析器和优化器。在服务层,连接器负责建立与客户端的连接,查询缓存用于存储和检索常用查询结果,以提高性能。分析器则解析SQL语句,生成语法树,而优化器负责选择最优的查询执行计划。这一流程确保了MySQL能够高效地处理各种复杂的查询请求。 ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • 基于 Vue 和 Element UI 实现的简洁登录界面设计
    本文介绍了一种利用 Vue.js 和 Element UI 框架构建的简洁登录界面设计。该设计不仅注重用户体验,还确保了界面的美观性和易用性。通过合理的布局和组件配置,实现了高效、响应式的登录功能,适用于多种前端应用场景。 ... [详细]
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社区 版权所有