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的生命周期

vue实例从创建到销毁的过程就是生命周期。vue框架内置的函数(钩子函数),随着生命周期自动执行,分为以下四个阶段,包含八个钩子函数。

在这里插入图片描述

一、初始化阶段

  1. beforeCreate()
    • 执行机制:new Vue()以后, vue内部给实例对象添加了一些属性和方法, data和methods初始化"之前"。
  2. created()
    • 使用场景: 网络请求, 注册全局事件。
    • 执行机制:data和methods方法初始化以后。

二、挂载阶段

  1. beforeMount()
    • 使用场景: 预处理data, 不会触发updated钩子函数。
    • 执行机制:真实DOM挂载之前。
  2. mounted()
    • 使用场景: 挂载后真实DOM。
    • 执行机制:真实DOM挂载以后。

三、更新阶段

  1. beforeUpdate()
    • 前提: 数据发生改变之后
    • 执行机制:更新之前。
  2. updated()
    • 使用场景: 获取真实DOM。
    • 执行机制:更新之前。

四、销毁阶段

  1. beforeDestroy()
    • 使用场景: 获取真实DOM。
    • 执行机制:更新之前。
  2. destroyed()
    • 执行机制: v-if=“false” 销毁Vue实例。
    • 使用场景:移除全局事件, 移除当前组件, 计时器, 定时器, eventBus移除事件$off方法。
  // 一. 初始化
    // new Vue()以后, vue内部给实例对象添加了一些属性和方法, data和methods初始化"之前"
    beforeCreate(){
          console.log("beforeCreate -- 执行");
          console.log(this.msg); // undefined
    },
    // data和methods初始化以后
    // 场景: 网络请求, 注册全局事件
    created(){
         console.log("created -- 执行");
          console.log(this.msg); // hello, Vue

        this.timer = setInterval(() => {
             console.log("哈哈哈");
          }, 1000)
    },

    // 二. 挂载
    // 真实DOM挂载之前
    // 场景: 预处理data, 不会触发updated钩子函数
    beforeMount(){
          console.log("beforeMount -- 执行");
          console.log(document.getElementById("myP")); // null

        this.msg = "重新值"
    },
    // 真实DOM挂载以后
    // 场景: 挂载后真实DOM
    mounted(){
          console.log("mounted -- 执行");
          console.log(document.getElementById("myP")); // p
    },

    // 三. 更新
    // 前提: data数据改变才执行
    // 更新之前
    beforeUpdate(){
        // console.log("beforeUpdate -- 执行");
        // console.log(document.querySelectorAll("#myUL>li")[4]); // undefined
    },
    // 更新之后
    // 场景: 获取更新后的真实DOM
    updated(){
         console.log("updated -- 执行");
        console.log(document.querySelectorAll("#myUL>li")[4]); // li
    },

    // 四. 销毁
    // 前提: v-if="false" 销毁Vue实例
    // 场景: 移除全局事件, 移除当前组件, 计时器, 定时器, eventBus移除事件$off方法
    beforeDestroy(){
        console.log('beforeDestroy -- 执行');
        clearInterval(this.timer)
    },
    destroyed(){
       console.log("destroyed -- 执行");
    }
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-10 13:19:49  更:2021-08-10 13:20:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/17 13:51:45-

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