码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【vue3】11.跟着官网学习vue3-生命周期钩子,onErrorCaptured错误捕获钩子的使用


    每日鸡汤:努力,现在可能觉得不过如此,混一天和努力一天看不出任何差别,三天两天也看不到任何变化,十天半个月也体现不出任何差距,但是两三个月后你就会看到气场不同。

    目录

    前言

    一、基本概念

    1. 生命周期

    2. 钩子

    二、注意事项总结

    1.onUnmounted

    2.onErrorCaptured之组件渲染

    总结


    前言

    本篇文章对应官网【生命周期钩子】


    一、基本概念

    1. 生命周期

    这段是废话,可以忽略

    什么是生命周期?就像人一样生老病死,我们的一生就是一个周期,一个轮回,每个人都一样,出生-长大-死亡。

    我们把组件当成一个人,它也有它一生必须经过的时间节点,就是组件的生命周期。

    2. 钩子

    这段也是废话,可以忽略

    钩子就是一个函数,其实我一直不理解,为啥好好的函数要起一个这个诡异的名字。没办法我们只能试图理解它。看一下这篇文章,可以理解一下,钩子就是一个事件监听函数。

    hook函数教程(一)什么是钩子 - 宇月--测试开发梦想家 - 博客园一、什么是钩子 我们可以首先从字面上了解钩子,钩子是干什么的呢?日常生活中,我们的钩子是用来钩住某种东西的,比如,说,鱼钩是用来钓鱼的,一旦鱼咬了钩,钩子就一直钩住鱼了,任凭鱼在水里怎么游,也逃不出鱼https://www.cnblogs.com/xwj-pandababy/articles/3464604.html关于各种生命周期的顺序啥的,官网已经很详细了,请仔细研读

    二、注意事项总结

    可以同时看一下 组合式API: 生命周期钩子

    1.onUnmounted

    这里面做的都是销毁操作,尤其是事件监听的销毁操作尤其重要,要不然监听函数会被反复的调用。

    2.onErrorCaptured之组件渲染

    这个没用过,所以很有必要自己动手试一下

    捕获组件的渲染报错,需要在父组件里面监听onErrorCaptured方法

    1. <template>{
    2. {{test.name}}
    3. <a-input v-model:value="inputValue" />
    4. template>
    5. <script lang="ts" setup>
    6. import { Input as AInput } from 'ant-design-vue';
    7. import { computed, defineEmits, defineProps } from 'vue';
    8. const props = defineProps({
    9. value: String,
    10. });
    11. const emits = defineEmits(['update:value']);
    12. const inputValue = computed({
    13. get() {
    14. return props.value || ''
    15. },
    16. set(v: string) {
    17. emits('update:value', v)
    18. }
    19. })
    20. script>
    1. <template>
    2. 当前的值:{{name}}
    3. <o-input v-model:value="name">o-input>
    4. template>
    5. <script lang="ts" setup>
    6. import { onErrorCaptured, ref } from 'vue';
    7. import OInput from './component/OInput.vue';
    8. const name = ref('init value')
    9. // 父组件监听方法
    10. // 注册一个钩子,在捕获了后代组件传递的错误时调用。 注意是后代组件中有错误
    11. onErrorCaptured((err) => {
    12. console.log('打印onErrorCaptured错误', err)
    13. })
    14. script>
    15. <style>
    16. #app {
    17. }
    18. style>

    错误传递规则,再在main.js中定一个应用级错误处理函数

    1. import { createApp } from 'vue';
    2. import App from './App.vue';
    3. import { Input } from 'ant-design-vue';
    4. import './assets/main.css';
    5. const app = createApp(App);
    6. app.config.errorHandler = (err) => {
    7. console.log('应用级错误', err);
    8. };
    9. app.use(Input);
    10. app.mount('#app');

    这个时候打印的错误就如下,注意,这个时候,被应用级错误捕获函数捕获后,app.vue就不会抛出错误了。

     再来试一下阻止错误向上传递吧


    总结

    官网那个关于生命周期的图,请有感情的朗读并背诵下来。

  • 相关阅读:
    SpringBoot整合Quartz示例
    【HarmonyOS】遇见的问题汇总
    Java项目:JSP在线租车服务系统
    Flink SQL --Flink 整合 hive
    IS215UCVEM08B IS215UCVEH2AE VMIVME-7614-132 350-017614-132 D
    答对这3个面试问题,薪资直涨20K
    【如何学习Python自动化测试】—— 浏览器操作
    使用具有 monadmin 或者 sysadmin 用户权限
    配电网稳定性的分析(Python代码实现)
    springboot自动装配
  • 原文地址:https://blog.csdn.net/qq_17335549/article/details/126719179
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号