Vue生命周期学习
转自https://www.w3cplus.com/vue/vue-instances-and-life-cycles.html
Vue实例虽然没有完全遵循MVVM模型,但Vue的设计无疑受到了它的启发。
- View:是看得到的,即视图,用到Vue的项目中来,它应该是“模板”。也就是用来挂载Vue实例的一个DOM元素,通常在项目根目录中
index.html
文件中出现,比如<div id="app"></div>
。 - Model:即模型(或数据),跟MVC中的Model一样,就是想要显示到模型上的数据,也是我们需要在程序生命周期中可能需要更新数据
- ViewModel:Vue实例将View和Model连接起来的桥梁
- Vue代码中
el:'#app'
牵着View,data: {}
牵着Model,而类似methods
充当一个控制者(Controller)的角色,可以修改Model的值。 - Vue实例属性和方法有很多:
注,上图来自于@老马自嘲的《Vue入门系列之Vue实例详解与生命周期》一文。
Vue提供的可以注册的钩子都在上图中红色框标注。他们是:
beforeCreate
:在实例初始化之后,数据观测(Data Observer)和event
/watcher
事件配置之前被调用create
:实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据(Data Observer)、属性和方法的运算,watch
/event
事件回调。然而,挂载阶段还没开始,$el
属性目前不可见beforeMount
:在挂载开始之前被调用:相关的render
函数首次被调用mounted
:el
被新创建的vm.$el
替换,并挂载到实例上去之后调用该钩子。如果root
实例挂载了一个文档内元素,当mounted
被调用时vm.$el
也在文档内beforeUpdate
:数据更新时调用,发生在虚拟DOM重新渲染和打补丁之前。你可以在这个钩子中进一步地更改状态,这不会触发附加的重渲染过程updated
:由于数据更改导致虚拟DOM重新渲染和打补丁,在这之后会调用该钩子。当这个钩子被调用时,组件DOM已经更新,所以你现在可以执行依赖于DOM的操作。然而在大多数情况下,你应该避免在此期间更改状态,因为这可能会导致更新无限循环。该钩子在服务器端渲染期间不被调用beforeDestroy
:实例销毁之前调用。在这一步,实例仍然完全可用destroyed
:Vue实例销毁后调用。调用后,Vue实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。该钩子在服务器端渲染期间不被调用来看一个生命周期的简单示例:
let app = new Vue({
el: '#app',
data() {
return {
name: '大漠'
}
},
beforeCreate: function () {
console.log('===== 创建前 =====')
console.log(this.name)
console.log(this.$el)
},
created: function () {
// 在实例创建之后同步调用
// 此时实例已结束解析选项
// 这意味着已建立:数据绑定,计算属性,方法,watcher/事件回调
// 但是还没有开始DOM编译,$el还不存在,但是实例存在,即this.name存在,可以打印出来
console.log('===== 已创建 =====')
console.log(this.name)
console.log(this.$el)
},
beforeCompile: function () {
console.log('===== 未开始编译 =====')
console.log(this.name)
console.log(this.$el)
},
compiled: function () {
// 在编译结束之后调用
// 此时所有的指令已生效,因而数据的变化将触发DOM更新
// 但是不担保$el已插入文档
console.log('===== 编译完成 =====')
console.log(this.name)
console.log(this.$el)
},
beforeMount: function () {
console.log('===== Mount之前 =====')
console.log(this.name)
console.log(this.$el)
},
mounted: function () {
console.log('===== Mount完成 =====')
console.log(this.name)
console.log(this.$el)
},
beforeUpdate: function () {
console.log('===== 更新前 =====')
console.log(this.name)
console.log(this.$el)
},
updated: function () {
console.log('===== 更新完成 =====')
console.log(this.name)
console.log(this.$el)
},
ready: function () {
// 在编译结束和$el 第一次插入文档之后调用,如果在第一次attached钩子之后调用
// 注意,必须是由Vue插入,比如 vm.$appendTo()等方法或指令更新,才会触发ready 钩子
console.log('===== 一切都准备好了 =====')
console.log(this.name)
console.log(this.$el)
},
attached: function () {
// app.$appendTo('#app2')暂时触发不了,不知道怎么解决
// 在 vm.$el插入DOM时调用。必须是由指令或实例方法,比如$appendTo()插入,直接操作vm.$el不会触发这个钩子
console.log('===== 插入DOM成功 =====')
console.log(this.name)
console.log(this.$el)
},
detached: function () {
// 触发事件 app.$destroy(true),其中参数true控制是否删除DOM节点或者app.$remove()
// 在vm.$el 从DOM中删除时调用。必须是由指令或实例方法删除,直接操作vm.$el不会触发这个钩子
console.log('===== 删除DOM成功 =====')
console.log(this.name)
console.log(this.$el)
},
beforeDestroy: function () {
// 触发方式,在console里面打印app.$destroy()
// 在开始销毁实例时调用。此时实例仍然有功能
console.log('===== 销毁前 =====')
console.log(this.name)
console.log(this.$el)
},
destroyed: function () {
// 触发方式,在console里面打app.$destroy()
// 其中app.$destroy(true)是删除DOM节点,会触发detached函数,但是实例仍然存在
// 在实例被销毁之后调用。此时所有的绑定和实例的指令已经解绑
// 注意是解绑不是销毁,所有的子实例也已经被销毁
console.log('===== 已销毁 =====')
console.log(this.name)
console.log(this.$el)
}
})打印出来的结果:
接着在控制台修改
data
的值,更新视图:这个时候触发
beforeUpdata
和updated
。接着执行app.$destroy()
:总结一下,对官方文档的那张图简化一下,就得到了这张图:
注:上图来自@浅白的《Vue生命周期》一文。示例也参考此文。
Vue生命周期学习的更多相关文章
- Vue生命周期学习总结
官方文档上关于Vue生命周期的图片大家一定很熟悉: 1.beforeCreate 实例.组件通过new Vue() 创建出来之后会初始化事件和生命周期,然后就会执行beforeCreate钩子函数,这 ...
- vue生命周期-学习心得
每个Vue实例在被创建之前都要经过一系列的初始化过程,也就是从开始创建.初始化数据.编译模板.挂载Dom.渲染→更新→渲染.销毁等一系列过程,这个过程就是vue的生命周期. 1 vue生命周期图 {: ...
- vue生命周期学习(watch跟computed)
1.watch钩子函数监听数据的变化 watch 的一个特点是,最初绑定的时候是不会执行的,要等到 firstName 改变时才执行监听计算. <div> <p>FullNam ...
- 学习vue生命周期
首先,每个Vue实例在被创建之前都要经过一系列的初始化过程,这个过程就是vue的生命周期.首先看一张图吧~这是官方文档上的图片相信大家一定都会很熟悉: 可以看到在vue一整个的生命周期中会有很多钩子函 ...
- 关于vue生命周期
官网给出的实例的生命周期图如下: beforeCreate(页面创建前),created(页面创建后),beforeMount(页面载入前),mounted(页面载入后),beforeUpdate(页 ...
- 面试题之(vue生命周期)
在面试的时候,vue生命周期被考察的很频繁. 什么是vue生命周期呢? Vue实例有一个完整的生命周期,也就是从开始创建.初始化数据.编译模板.挂载Dom.渲染→更新→渲染.卸载等一系列过程,我们称这 ...
- vue生命周期钩子
转载自:https://segmentfault.com/a/1190000008010666?utm_source=tag-newest https://segmentfault.com/a/119 ...
- Vue生命周期 以及应用场景
首先一张官方图 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- 14、前端知识点--Vue生命周期浅析
vue生命周期 每个Vue实例或组件从创建到显示再到废弃的过程就是vue的生命周期.很多时候我们希望能在这个过程中执行一些操作,于是就有了生命周期钩子. 生命周期钩子函数允许我们在实例不同阶段执行各种 ...
随机推荐
- PHP全局变量与SESSION 漏洞(global 与 session)
先看这一段简单的代码 <?php session_start();$_SESSION[‘isadmin’]=’yes’;$isadmin=’no’;echo $_SESSION[‘isadmin ...
- deepin配置反向代理映射本地到公网
这里我是用的小米球的免费ngrok 相信deepin的新用户在配置反向代理时,会感觉到一脸茫然,因为一开始我也是这样,但经过短暂的了解了deepin后,发现,其实与在Debian上配置并没有什么区别! ...
- windows 域的安装方法
前面的博客中我们知道了 Windows AD域的升级,下面我谈谈Windows域的安装和卸载. 卸载AD域 配置备份AD域 安装子域 删除子域(必须在根域管理员模式下删除,否则无法删除) 删除命令 导 ...
- Https 客户端与服务器交互过程梳理
本文试图以通俗易通的方式介绍Https的工作原理,不纠结具体的术语,不考证严格的流程.我相信弄懂了原理之后,到了具体操作和实现的时候,方向就不会错,然后条条大路通罗马.阅读文本需要提前大致了解对称加密 ...
- DataTables复杂表头
工作上的需要,要做一个复杂的表头的DataTables thead如下 遇到的问题(详细问题可以浏览官网的答案 链接) 需自定义表头(thead),如果不自定义则会 Cannot read prope ...
- GDB:从单线程调试到多线程调试(MFiX单步调试)
GDB:从单线程调试到多线程调试 1. 裸跑GDB 1.1 安装GDB sudo apt-get install gdb 1.2 编译程序 由于需要调试,因此编译的时候需要添加-g编译参数: 1.3 ...
- C#控制台画图形
static void Main(string[] args) { //九九乘法 Console.WriteLine("九九乘法口诀"); ; i <= ; i++) { ; ...
- WPF实现WORD 2013墨迹批注功能
1 前言 WORD 2013可以使用墨迹在文档上面标注,本文讲述通过WPF第三方控件实现类似主要功能如下: 名称 描述 墨迹标注 不论是否触摸屏环境下可以开始墨迹功能,并实现鼠标/触摸在文档任意位置绘 ...
- java翻译到mono C#实现系列(1) 重写返回键按下的事件
今天看到群里的朋友问怎么按下返回键的时候提示信息,百度了下,就参考网上一个java版示例做了.没啥技术含量,就权当丰富下mono for android的小代码. 直接在mono新建的APP上修改的. ...
- Jexus进程守护工具jws.guard
一个运行中的进程,难免会因为各种各样的原因无缘无故的宕掉(比如网站瞬间的负载过高.内存不足等),而Jexus宕掉的后果往往只有一个:对外提供服务的网站无法访问了.因此,我们需要最大限度的保障我们的网站 ...