IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue的生命周期 -> 正文阅读

[JavaScript知识库]Vue的生命周期

一、?生命周期方法详解

钩子函数详情场景备注
beforeCreate实例初始化之后,组件被创建时期,这个时候的 el,data,message 都是 underfined可以加入 loading 事件;在服务器端的应用场景中,这个时候发送数据请求比较多一些
created实例创建完成后,data、methods 被初始化结束 loading 事件;推荐这个时候发送请求数据,尤其是返回的数据与绑定事件有关时
beforeMount挂载初始之前,完成 el 初始化,render 被初次调用也可以发送数据请求在服务器端渲染期间不会被调用
mounted完成挂载获取 el 中 DOM 元素,进行 DOM 操作;如果返回的数据操作依赖 DOM 完成,推荐这个时候发送数据请求在服务器端渲染期间不会被调用
beofreUpdate挂载开始之前调用挂载完成之前访问现有 DOM ,比如手动移除已添加的事件监听器;也可以进一步修改数据在服务器渲染期间不会被调用,只有初次渲染会在服务端调用
updated由于数据更改,重新渲染界面时调用可执行依赖于 DOM 的操作服务器端渲染期间不会被调用
activatedkeep-alive 组件激活时调用服务器端渲染期间不会被调用
deactivated组件停用时调用服务器端渲染期间不会被调用
beforeDestroy实例销毁之前调用删除钱发出确认信息;清理定时器服务器端渲染期间不会被调用
destroyed实例销毁后调有。调用后,所有东西都会被解绑,所有的事件监听器会被移动,子实例也会被销毁提示已删除服务器端渲染期间不会被调用

二、生命周期执行流程

1.创建

1.我们在new Vue()新建Vue实例后会先初始化数据、事件、生命周期函数。然后执行beforeCreate()函数:组件创建之前(此时没有数据)。在进行对初始化数据的注入和校验后执行created():组件创建完成。

2.然后判断是否有el元素,如果有el元素就直接判断是否有template模板元素。如果没有el元素就会先判断是否调用vm.$mounted(el)函数,然后在判断是否有template模板元素。

3.如果有template模板元素就直接render()进行渲染。? ?没有的话就会把el外部的HTML(就是你绑定的el元素)作为template编译。

4.然后执行beforeMount():即将挂载、Dom挂载之前。在创建vm.$el并用其替换el。? (这部分是虚拟Dom)

5.然后执行mounted():DOM挂载完成。

2.运行

1.如果data数据发生改变,会到beforeUpdate():更新之前的Dom,然后再次虚拟Dom重新渲染并应用更新。再执行updated():更新之后的Dom,进行再次挂载完成。

3.销毁

1.比如当组件使用v-if进行销毁时,会到beforeDestroy():销毁之前,进行解除绑定、销毁子组件以及事件监听器。然后destroyed():销毁完成

三、代码

activated()和deactivated()要配合<keep-alive></keep-alive>使用? ??keep-alive将目前状态放入缓存,下次获取在到缓存中获取使用。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
.active{
    color: red;
}
</style>
<body>
    <div id="app">
        <!-- 使用子组件 -->
        <App></App>
    </div>
    <script src="vue .js"></script>
    <script>
        // beforeCreate
        // created
        // beforeMount
        // mounted
        // beforeUpdate
        // updated
        // activated
        // deactivated
        // beforeDestroy
        // destroyed
        Vue.component('Test',{
            data(){
                return{
                    msg:'小张同学',
                    isRed:false
                }
            },
            methods: {
                handleClick() {
                    this.msg =  '学习vue生命周期'
                    this.isRed = !this.isRed;
                },
            },
            template:`
                <div>
                    <button @click='handleClick'>改变</button>
                   <h3 :class='{active:isRed}'>{{msg}}</h3>
                   
                </div>
            `,
            beforeCreate(){
                console.log('组件创建之前',this.$data);
            },
            created () {
                // 再这个方法中请求发送ajax,请求后端的数据
                console.log('组件创建完成',this.$data);
            },
            beforeMount () {
                // 即将挂载
                console.log('Dom挂载之前',document.getElementById('app'));
            },
            mounted () {
                console.log('DOM挂载完成',document.getElementById('app'));
            },
            beforeUpdate () {
                // 获取更新之前的Dom
                console.log('更新之前的Dom',document.getElementById('app').innerHTML);
            },
            updated () {
                // 获取最新的Dom
                console.log('更新之后的Dom',document.getElementById('app').innerHTML);
            },
            beforeDestroy () {
                console.log('销毁之前');
            },
            destroyed () {
                console.log('销毁完成');
            },
            activated () {
                console.log('组件被激活了');
            },
            deactivated () {
                console.log('组件被停用了');
            },
        })

        const App = {
            data(){
                return{
                    isShow:true
                }
            },
            methods: {
                myClick() {
                    this.isShow  = !this.isShow;
                }
            },
            components:{

            },
            template:`
            <div>
                <keep-alive>
                    <Test v-if='isShow'></Test>
                </keep-alive>
                <button @click='myClick'>创建销毁</button>
            </div>
                `,
                }
      
        new Vue({
            el:'#app',
            data:{

            },
            components:{
                //挂载子组件
                App
            }
        })
    </script>
</body>
</html>

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-02 16:39:54  更:2021-12-02 16:42:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 14:14:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码