vue组件的生命周期

一、组件运行的过程

开始--》import导入组件--》components注册组件--》以标签形式使用组件--》在内存中创建组建的实例对象--》把创建的组件实例渲染到页面上--》组件切换时销毁需要被隐藏的组件--》结束

组件的生命周期指的是:组件从创建、运行(渲染)、销毁的整个过程,强调的是一个时间段。

二、监听组件的不同时刻

vue框架为组件内置了不同时刻的生命周期函数,生命周期函数会伴随着组件的运行而自动调用。

1.当组件在内存中被创建完毕后,会自动调用created函数

2.当组件被成功渲染到页面上之后,会自动调用mounted函数

3.当组件被销毁完毕后,会自动调用unmounted函数

三、监听组件的更新

当组件的data数据更新后,vue会自动重新渲染组件的dom结构,从而保证view视图展示的数据和model数据源保持一致。

当组件被重新渲染完毕后,会自动调用updated生命周期函数。

四、组件中主要的生命周期函数

|-----------|----------------|------|------|-------------|
| 生命周期函数 | 执行时机 | 所属阶段 | 执行次数 | 应用场景 |
| created | 组件在内存中创建完毕后 | 创建阶段 | 唯一1次 | 发ajax请求初始数据 |
| mounted | 组件初次在页面中渲染完毕后 | 创建阶段 | 唯一1次 | 操作dom元素 |
| updated | 组件在页面中被重新渲染完毕后 | 运行阶段 | 0或多次 | - |
| unmounted | 组件被销毁后(页面和内存) | 销毁阶段 | 唯一1次 | - |

在实际开发中,created是最常用的生命周期函数。

五、完整的生命周期函数

|---------------|----------------|------|------|-------------|
| 生命周期函数 | 执行时机 | 所属阶段 | 执行次数 | 应用场景 |
| beforeCreate | 在内存中开始创建组件之前 | 创建阶段 | 唯一1次 | - |
| created | 组件在内存中创建完毕后 | 创建阶段 | 唯一1次 | 发ajax请求初始数据 |
| beforeMount | 在把组件初次渲染到页面之前 | 创建阶段 | 唯一1次 | - |
| mounted | 组件初次在页面中渲染完毕后 | 创建阶段 | 唯一1次 | 操作dom元素 |
| beforeUpdate | 在组件被重新渲染之前 | 运行阶段 | 0或多次 | - |
| updated | 组件在页面中被重新渲染完毕后 | 运行阶段 | 0或多次 | - |
| beforeUnmount | 在组件被销毁之前 | 销毁阶段 | 唯一1次 | - |
| unmounted | 组件被销毁后(页面和内存) | 销毁阶段 | 唯一1次 | - |

为什么不在beforeCreate中发ajax请求初始数据?

在beforeCreate中,无法访问到data里面数据,请求到的数据无法挂载到da'ta中供组件渲染使用

操作dom在mounted函数中

javascript 复制代码
<template>
  {{ count }}
  <button @click="count+=1">按钮</button>
</template>
<script>
export default {
  data(){
    return{
      count:1
    }
  },
  beforeCreate(){
    console.log('beforeCreate,在内存中开始创建组件之前',this.count);
  },
  created(){
    console.log('created,组件在内存中被创建了',this.count);
  },
  beforeMount(){
    console.log('beforeMount,在把组件初次渲染到页面之前');
  },
  mounted(){
    console.log('mounted,组件第一次被渲染到页面上了');
  },
  beforeUpdate(){
    console.log('beforeUpdate,在组件被重新渲染之前');
  },
  updated(){
    console.log('updated,组件被重新渲染完毕了');
  },
  beforeUmounte(){
    console.log('beforeUmounte,组件被销毁之前');
  },
  unmounted(){
    console.log('unmounted,组件被销毁完毕了');
  }
}
</script>
相关推荐
qq_177767373 分钟前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462108 分钟前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n15 分钟前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon36 分钟前
理解vue中的ref
前端·javascript·vue.js
jin1233221 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_920931702 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
落霞的思绪2 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q2 小时前
CSS 笔记2 (属性)
前端·css·笔记
Anastasiozzzz2 小时前
LeetCode Hot100 295. 数据流的中位数 MedianFinder
java·服务器·前端
橙露3 小时前
React Hooks 深度解析:从基础使用到自定义 Hooks 的封装技巧
javascript·react.js·ecmascript