当前位置: 首页 > article >正文

Vue学习记录之五(组件/生命周期)

一、组件

在每一个.vue文件可以看作是一个组件,组件是可以复用的,每个应用可以看作是一棵嵌套的组件树。
在这里插入图片描述
在Vue3中,组件导入以后即可直接使用。
在这里插入图片描述

二、组件的生命周期

生命周期就是从诞生(创建)到死亡(销毁) 的过程。
Vue3 组合式API中(setup语法糖模式),是没有beforeCreate 和 created 这两个过程的。可以使用setup去代替。
在这里插入图片描述
运行流程

<template>
    <div>
    </div>
</template>
<script setup lang='ts'>
import { ref,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted } from 'vue'
console.log("setup")
//创建
onBeforeMount(()=>{
  console.log("创建之前==========")
})
onMounted(()=>{
  console.log("创建完成==========")
})
//更新的钩子
onBeforeUpdate(()=>{
  console.log("更新组件之前==========")
})
onUpdated(()=>{
  console.log("更新组件完成==========")
})
// 销毁的钩子
onBeforeUnmount(()=>{
  console.log("销毁之前==========")
})
onUnmounted(()=>{
  console.log("销毁完成==========")
})

</script>
<style scoped>

</style>

在这里插入图片描述

<template>
    <div ref="getdiv">{{ name }}</div>
    <button @click="change">修改name</button>
</template>
<script setup lang='ts'>
import { ref,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted } from 'vue'
console.log("setup")
const name = ref("lvmanba")
const getdiv = ref<HTMLDivElement>()  //注意这里的变量名要和上面的ref属性的名称一致。
const change = () =>{
  name.value = "bird"
}
/*
1、在onMounted之前读取不到dom, onMounted可以读取到。
2、有内容更新的时候,才能触发onBeforeUpdate 和 onUpdated, 如上面点击修改内容的时候
3、onBeforeUpdate 是获取更新之前的dom,onUpdated才能获取更新之后的内容
*/
//创建
onBeforeMount(()=>{
  console.log("创建之前==========",getdiv.value)  //创建之前是undefined
})
onMounted(()=>{
  console.log("创建完成==========",getdiv.value) //这里可以获取到值
})
//更新的钩子
onBeforeUpdate(()=>{
  console.log("更新组件之前==========",getdiv.value?.innerHTML) //更新之前是lvmanba,也就是内容还没有被修改。
})
onUpdated(()=>{
  console.log("更新组件完成==========",getdiv.value?.innerHTML) // 更新之后是bird
})
// 销毁的钩子
onBeforeUnmount(()=>{
  console.log("销毁之前==========")
})
onUnmounted(()=>{
  console.log("销毁完成==========")
})

</script>

使用销毁功能:
下面的是插件A.vue

<template>
    <div ref="getdiv">{{ name }}</div>
    <button @click="change">修改name</button>
</template>
<script setup lang='ts'>
import { ref,
    onBeforeMount,onMounted,
    onBeforeUpdate,onUpdated,
    onBeforeUnmount,onUnmounted,
    onRenderTracked,onRenderTriggered
 } from 'vue'
console.log("setup")
const name = ref("lvmanba")
const getdiv = ref<HTMLDivElement>()  //注意这里的变量名要和上面的ref属性的名称一致。
const change = () =>{
  name.value = "bird"
}
/*
1、在onMounted之前读取不到dom, onMounted可以读取到。
2、有内容更新的时候,才能触发onBeforeUpdate 和 onUpdated, 如上面点击修改内容的时候
3、onBeforeUpdate 是获取更新之前的dom,onUpdated才能获取更新之后的内容
*/
//创建
onBeforeMount(()=>{
  console.log("创建之前==========",getdiv.value)  //创建之前是undefined
})
onMounted(()=>{
  console.log("创建完成==========",getdiv.value) //这里可以获取到值
})
//更新的钩子
onBeforeUpdate(()=>{
  console.log("更新组件之前==========",getdiv.value?.innerHTML) //更新之前是lvmanba,也就是内容还没有被修改。
})
onUpdated(()=>{
  console.log("更新组件完成==========",getdiv.value?.innerHTML) // 更新之后是bird
})
// 销毁的钩子
onBeforeUnmount(()=>{
  console.log("销毁之前==========")
})
onUnmounted(()=>{
  console.log("销毁完成==========")
})
onRenderTracked((e)=>{
    console.log("onRenderTracked:",e)
})
onRenderTriggered((e)=>{
    console.log("onRenderTriggered:",e)
})

</script>

入口文件App.vue
引入组件,并展示组件。

<template>
    <div>
      <!--
        当一个组件绑定了v-if,会触发组件的创建和销毁。v-show 无此功能。
      -->
      <A v-if="flag"></A> <br><br>
      <button @click="flag = !flag">{{ flag == true? "销毁":"创建"}}</button>
    </div>
</template>
<script setup lang='ts'>
import { ref,reactive } from 'vue'
import A from './components/A.vue';
const flag = ref<boolean>(false)
</script>

在这里插入图片描述
下面是有一个完整的生命周期:
在这里插入图片描述
其次 还有 onRenderTracked,onRenderTriggered 两个钩子,主要是用来调试使用的。


http://www.kler.cn/news/312510.html

相关文章:

  • IO流体系(FiletOutputStream)
  • Go Testify学习与使用
  • Linux环境变量进程地址空间
  • 毕业设计选题:基于springboot+vue+uniapp的驾校报名小程序
  • MySQL从入门到精通二
  • Java企业面试题3
  • MySQL_图形管理工具简介、下载及安装(超详细)
  • 对ViT 中Patch Embedding理解
  • 用友U8二次开发工具KK-FULL-*****-EFWeb使用方法
  • Vue 依赖注入组件通信:provide / inject 使用详解
  • QUIC 和 HTTP/3:提升网络性能的关键技术
  • Spring Cloud Config 动态刷新原理分析
  • 视频单目标跟踪研究
  • 鸿蒙next web组件和h5 交互实战来了
  • 零基础到项目实战:Node.js版Selenium WebDriver教程
  • Gitee Pipeline 从入门到实战【详细步骤】
  • Spring Boot框架下校园信息管理平台的构建
  • Unborn安装CUDA Toolkit 12.2
  • android10 系统定制:增加应用使用数据埋点,应用使用时长统计
  • 2013-2023年专精特新小巨人企业财务指标数据
  • MySQL 数据库备份与恢复指南
  • 抖音下载别人作品怎么去掉水印
  • Spring Boot 集成 Redisson 实现消息队列
  • 【C#生态园】提升C#开发效率:深入了解自然语言处理库与工具
  • (Java企业 / 公司项目)点赞业务系统设计-批量查询点赞状态(二)
  • 探索未来智能:Moonshot AI 引领AI新纪元——M1超级模型
  • css百分比布局中height:100%不起作用
  • 牛客小白月赛101(栈、差分、调和级数、滑动窗口)
  • Java中out流中打印方法详解
  • 【设计模式-享元】