我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中的生命周期实例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中的生命周期实例分析

这篇文章主要介绍“Vue中的生命周期实例分析”,在日常操作中,相信很多人在Vue中的生命周期实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue中的生命周期实例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

什么是vue的生命周期

Vue中的生命周期是指组件从创建到销毁的一系列过程。看下面这张官方文档的图:

Vue中的生命周期实例分析

从图片中可以看出Vue的整个生命周期包括8个状态,按照先后顺序分别为:

  • beforeCreate

  • Created

  • beforeMount

  • mounted

  • beforeUpdate

  • updated

  • beforeDestroy

  • destroyed

Vue组件的生命周期共分为三个阶段,如下图所示:

Vue中的生命周期实例分析

创建阶段和销毁阶段在组件的生命周期中只会执行一次,而更新阶段会执行多次。

先看一下创建阶段完成的事情:

Vue中的生命周期实例分析

在看更新阶段完成的事情:

Vue中的生命周期实例分析

最后在看一下销毁阶段完成的事情:

Vue中的生命周期实例分析

先看下面的一段代码:

<!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>生命周期</title>    <!--引入vue.js-->    <script class="lazy" data-src="./js/vue.js" ></script>    <script>        window.onload=function(){            new Vue({                el:'#app',// 2.0不允许挂载到html,body元素上                data:{                    msg:'welcome'                },                methods:{                    update(){                        this.msg="欢迎";                    },                    destroy(){                        this.$destroy();                    }                },                //创建前状态  el和data并未初始化                beforeCreate(){                    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.msg)                     console.log('组件实例刚刚创建,还未进行数据观测和事件配置');                },                created(){//常用  创建完毕状态   完成了data数据的初始化  el没有                    console.group('------created创建完毕状态------');                    console.log("%c%s", "color:red","el     : " + this.$el); //undefined                    console.log("%c%s", "color:red","data   : " + this.$data); //已被初始化                     console.log("%c%s", "color:red","message: " + this.msg); //已被初始化                    console.log("实例已经创建完成,并且已经进行数据观测和事件配置")                },                beforeMount(){  //挂载前状态 完成了el和data初始化                    this.msg="112233";                    console.group('------beforeMount挂载前状态------');                    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.msg); //已被初始化                    console.log("模板编译之前,还没挂载");                },                mounted(){//常用  挂载结束状态  完成挂载                    console.group('------mounted 挂载结束状态------');                    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.msg); //已被初始化                     console.log("模板编译之后,已经挂载,此时才会有渲染页面,才能看到页面上数据的显示")                },                beforeUpdate(){   //更新前状态                    console.group('------beforeUpdate 更新前状态------');                    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.msg);                 },                updated(){   //更新完成状态                    console.group('------updated 更新完成状态------');                    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.msg);                 },                beforeDestroy(){   //销毁前状态                    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.msg);                 },                destroyed(){  //销毁完成状态                    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.msg)                }            });        }    </script></head><body>    <div id="app">        <input type="text" v-model="msg" />        <button @click="update">更新数据</button>        <button @click="destroy">销毁组件</button>     </div></body></html>

在控制台的console里面查看运行后的效果:

Vue中的生命周期实例分析

然后点击“更新数据”按钮,会看到input绑定的数据发生变化:

数据更新前:

Vue中的生命周期实例分析

数据更新后:

Vue中的生命周期实例分析

控制台显示的打印信息:

Vue中的生命周期实例分析

最后点击“销毁组件”按钮,查看控制台显示的打印信息:

Vue中的生命周期实例分析

这样,一个完整的Vue实例生命周期就结束了。

注意:Vue组件被销毁以后,这时如果在更新数据就不会有任何反应了,因为组件已经被销毁

到此,关于“Vue中的生命周期实例分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中的生命周期实例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue中的生命周期实例分析

这篇文章主要介绍“Vue中的生命周期实例分析”,在日常操作中,相信很多人在Vue中的生命周期实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue中的生命周期实例分析”的疑惑有所帮助!接下来,请跟着小编
2023-06-29

Vue生命周期实例分析

这篇文章主要介绍“Vue生命周期实例分析”,在日常操作中,相信很多人在Vue生命周期实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue生命周期实例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-07-02

vue生命周期的示例分析

这篇文章主要介绍了vue生命周期的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。vue生命周期图解感谢你能够认真阅读完这篇文章,希望小编分享的“vue生命周期的示例分
2023-06-14

Vue组件生命周期实例分析

本文小编为大家详细介绍“Vue组件生命周期实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue组件生命周期实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1. 组件的生命周期的四个阶段组件的生命周
2023-06-27

Laravel的生命周期实例分析

本篇内容主要讲解“Laravel的生命周期实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel的生命周期实例分析”吧!Laravel的生命周期 A世间万物皆有生命周期,当我们使用
2023-06-30

React的生命周期实例分析

这篇文章主要讲解了“React的生命周期实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React的生命周期实例分析”吧!一、React生命周期React 生命周期分为三种状态1. 初
2023-07-02

Vue生命周期和MVVM框架实例分析

这篇文章主要介绍“Vue生命周期和MVVM框架实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue生命周期和MVVM框架实例分析”文章能帮助大家解决问题。生命周期组件从开始到结束的全过程创建
2023-07-02

React中生命周期的示例分析

这篇文章将为大家详细讲解有关React中生命周期的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。React的生命周期两张图带你理解 React的生命周期React的生命周期(旧)class Lif
2023-06-20

Java之Bean的生命周期实例分析

本篇内容主要讲解“Java之Bean的生命周期实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java之Bean的生命周期实例分析”吧!一、什么是生命周期首先理解下什么是生命周期?从创建到
2023-07-02

Android开发中Widget的生命周期实例分析

本文实例分析了Android开发中Widget的生命周期。分享给大家供大家参考,具体如下: Widget是android中桌面小控件,创建时必须继承AppWidgetProvider,AppWidgetProvider其实就是继承了Broa
2022-06-06

docker中pod生命周期的示例分析

这篇文章给大家分享的是有关docker中pod生命周期的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 查看资源配置清单帮助 [root@master manifests]# kubectl expla
2023-06-04

小程序app.js生命周期实例分析

这篇文章主要介绍了小程序app.js生命周期实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇小程序app.js生命周期实例分析文章都会有所收获,下面我们一起来看看吧。小程序的生命周期App.jsApp()
2023-06-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录