【Vue3基础】组件保持存活、异步加载组件

一、组件保持存活

1、需求描述

点击按钮跳转到其他组件后,原组件不会被销毁

2、知识整理

1)组件生命周期

创建期:beforeCreate、created

挂载期:beforeMount、mounted

更新期:beforeUpdate、updated

销毁期:beforeUnmount、unmounted

2)保持组件存活keep-alive

复制代码
 <keep-alive>
    <component :is="tabComponent"></component>
  </keep-alive>

3)实现异步组件加载

复制代码
defineAsyncComponent

3、代码演示

1)文件

2)App.vue文件

复制代码
<template>
  <keep-alive>
    <component :is="tabComponent"></component>
  </keep-alive>
  <button @click="changeHandle">切换按钮</button>
</template>
<script>
import ComponentA from "./components/ComponentA.vue";
import ComponentB from "./components/ComponentB.vue";
export default{
  data(){
    return{
      tabComponent:"ComponentA"
    }
  },
  components: { 
    ComponentA,
    ComponentB
  },
  methods:{
    changeHandle(){
      this.tabComponent=this.tabComponent=="ComponentA"?"ComponentB":"ComponentA"
    }
  }
}
</script>

3)ComponentA.vue文件

复制代码
<template>
    <h3>ComponentA</h3>
    <p>{{ message }}</p>
    <button @click="updateHandle">更新数据</button>
</template>
<script>
export default{
    data(){
        return {
            message:"老数据"
        }
    },
    beforeUnmount(){
        console.log("组件卸载之前");
    },
    unmounted(){
        console.log("组件卸载之后");
    },
    methods:{
        updateHandle(){
            this.message="新数据"
        }
    }
}
</script>

4)ComponentB.vue文件

复制代码
<template>
    <h3>ComponentB</h3>
</template>
<script>

</script>

5、效果展示

1)打开浏览器

2)点击"更新数据"按钮,"老数据"将变为"新数据"

3)点击"切换按钮",跳转到组件B中

4)再点击"切换按钮",跳转回组件A,仍保持显示"新数据"

>>>

二、 异步加载组件

1、关键代码 App.vue文件

复制代码
<script>
import ComponentA from "./components/ComponentA.vue";
//import ComponentB from "./components/ComponentB.vue";
//异步加载B组件
import { defineAsyncComponent } from "vue";
const ComponentB=defineAsyncComponent(()=>import("./components/ComponentB.vue"))

2、效果展示

1)登录浏览器 ,B组件未被加载

2)点击切换按钮后,才加载B组件

>

三、学习链接

https://www.bilibili.com/video/BV1Rs4y127j8?p=37&spm_id_from=pageDriver&vd_source=841fee104972680a6cac4dbdbf144b50

相关推荐
helloyaren3 小时前
Docker Desktop里搭建RabbitMq 4.1.3集群的保姆级教程
学习·rabbitmq·集群
艾莉丝努力练剑3 小时前
【C语言16天强化训练】从基础入门到进阶:Day 6
c语言·数据结构·学习·算法
Insist7534 小时前
k8s----学习站点搭建
学习
月盈缺4 小时前
学习嵌入式第二十三天——数据结构——栈
数据结构·学习
mysla5 小时前
嵌入式学习day34-网络-tcp/udp
服务器·网络·学习
Moonnnn.5 小时前
【51单片机学习】AT24C02(I2C)、DS18B20(单总线)、LCD1602(液晶显示屏)
笔记·单片机·学习·51单片机
牛奶咖啡136 小时前
学习设计模式《二十三》——桥接模式
学习·设计模式·桥接模式·认识桥接模式·桥接模式的优点·何时选用桥接模式·桥接模式的使用示例
Jenkinscao7 小时前
我从零开始学习C语言(13)- 循环语句 PART2
c语言·开发语言·学习
新子y8 小时前
【操作记录】我的 MNN Android LLM 编译学习笔记记录(一)
android·学习·mnn
✎ ﹏梦醒͜ღ҉繁华落℘9 小时前
单片机学习---字节对齐
单片机·嵌入式硬件·学习