vue哪些情况称作“销毁组件”

在 Vue.js 中,组件被销毁是指组件从 DOM 中被移除,并且相关的资源和引用被清理。以下是组件被销毁的几种常见情况:

1. 动态组件切换

当使用 v-ifv-for 等指令动态切换组件时,组件会被销毁。例如:

vue 复制代码
<template>
  <div>
    <button @click="showComponent = !showComponent">
      切换组件
    </button>
    <component-a v-if="showComponent" />
  </div>
</template>

<script>
import ComponentA from './ComponentA.vue';

export default {
  components: {
    ComponentA
  },
  data() {
    return {
      showComponent: true
    };
  }
};
</script>
  • showComponentfalse 时,ComponentA 会被销毁,其 beforeUnmount 钩子会被触发。

2. 路由切换

当使用 Vue Router 进行页面跳转时,当前路由组件会被销毁。例如:

vue 复制代码
<template>
  <div>
    <router-link to="/home">Home</router-link>
    <router-link to="/about">About</router-link>
    <router-view />
  </div>
</template>
  • 当从 /home 跳转到 /about 时,/home 对应的组件会被销毁,其 beforeUnmount 钩子会被触发。

3. 整个应用卸载

当整个 Vue 应用被卸载时,所有组件都会被销毁。例如:

javascript 复制代码
const app = Vue.createApp(App);
const vm = app.mount('#app');

// 卸载整个应用
vm.unmount();
  • 调用 vm.unmount() 会触发所有组件的 beforeUnmount 钩子。

4. 关闭页面

当用户关闭浏览器标签页或刷新页面时,整个 Vue 应用会被销毁,所有组件的 beforeUnmount 钩子都会被触发。

5. 跳转页面

  • 单页面应用(SPA):如果使用 Vue Router 进行页面跳转,当前页面的组件会被销毁。
  • 传统页面跳转 :如果使用 <a> 标签或 window.location.href 进行页面跳转,浏览器会加载新页面,旧页面的所有组件都会被销毁。

总结

组件被销毁的情况包括:

  • 动态组件切换(如 v-ifv-for)。
  • 路由切换(使用 Vue Router)。
  • 整个应用卸载。
  • 关闭页面或刷新页面。
  • 跳转页面(无论是 SPA 还是传统页面跳转)。

在这些情况下,Vue 会自动调用组件的 beforeUnmountunmounted 生命周期钩子,用于执行清理操作。

相关推荐
贵州数擎科技有限公司11 分钟前
霓虹沙尘暴的 Three.js 实现
前端·webgl
一只叁木Meow12 分钟前
电商 SKU 选择器:用算法实现优雅的用户交互
前端·javascript·算法
笔优站长14 分钟前
vue-sign-canvas v2 重构复盘:从 Vue 2 签名板到 Vue 3 + TypeScript 组件库
前端·vue.js
Aolith18 分钟前
事件驱动设计:我如何为校园论坛实现消息通知功能
前端·vue.js
代码煮茶19 分钟前
Vue3 Mock 数据实战 | 用 Mockjs + vite-plugin-mock 搭建前端独立开发环境
javascript·vue.js
yingyima19 分钟前
GitHub Actions 定时任务 schedule 踩坑实录:核心语法与实战技巧
前端
代码煮茶19 分钟前
CSS 单位完全指南:px、em、rem、vw、vh、clamp 详解
前端·css
KaMeidebaby24 分钟前
卡梅德生物技术快报|PROTAC 药物降解蛋白原理及数据库平台开发全流程
前端·数据库·其他·百度·新浪微博
玄米乌龙茶1231 小时前
LLM成长笔记(七): AI 应用框架与编排
前端·人工智能·笔记
芯芯点灯2 小时前
gd32f303烧录提示Flash Timeout. Reset the Target and try it again.;
开发语言·前端·javascript