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

Ant ASpin自定义 indicator 报错

目录

一、问题

二、原因及解决方法

三、总结


一、问题

1.太多地方用到 Aspin了,还要使用h来自己,写style渲染。想着封装一下传值就可以。

2.没想到还搞出问题:线下报错,线上不报错。

3.报错具体如下:

chunk-QEPXSSG5.js?v=da510c8d:7137 Uncaught (in promise) TypeError: Cannot read properties of null (reading 'type')at unmountComponent (chunk-QEPXSSG5.js?v=da510c8d:7137:18)at unmount (chunk-QEPXSSG5.js?v=da510c8d:7048:7)at unmountChildren (chunk-QEPXSSG5.js?v=da510c8d:7167:7)at unmount (chunk-QEPXSSG5.js?v=da510c8d:7068:9)at unmountComponent (chunk-QEPXSSG5.js?v=da510c8d:7147:7)at unmount (chunk-QEPXSSG5.js?v=da510c8d:7048:7)at unmountChildren (chunk-QEPXSSG5.js?v=da510c8d:7167:7)at unmount (chunk-QEPXSSG5.js?v=da510c8d:7076:9)at unmountChildren (chunk-QEPXSSG5.js?v=da510c8d:7167:7)at unmount (chunk-QEPXSSG5.js?v=da510c8d:7076:9)
Promise.then		
callAsyncFunc	@	useAsyncLoading.ts:17
await in callAsyncFunc		
handleCheck	@	OnlineInvoice.vue:256

4.报错的地方是 loading.value=false这行代码,大致意思是组件没有正常卸载。但是我也没有写啥呀。就很常见的逻辑:调接口前loading,调完接口后取消loading而已。

5.具体代码如下:

6.我推测的错误原因:

        1)Asteps异步,还没有加载完。但是吧,Asteps完全就是一个样式,和逻辑没有啥关系

        2)handleNext影响逻辑,去除,也没有用

        3)DeepSeek问了一下,它说可能是CommonDrawer控制显示的isShowModal没有正确执行。试了一直显示也没有用

        4)真是奇了怪呀,我啥也没写呀,看着没有问题呀。

二、原因及解决方法

1.问了一下大佬,然后说CommonLoading有问题,我也是蒙圈了。设想了十几种可能性,都是在错误的道路上无效努力。

2.具体代码如下:乍一看,好像没有毛病呀。但是吧,把他注释了还真不报错了。

<template><!-- 加载中 --><ASpin :indicator="indicator"></ASpin>
</template>
<script lang="ts" setup>
import { Loading3QuartersOutlined } from '@ant-design/icons-vue'const props = withDefaults(defineProps<{ fontSize?: number; svg?: any; color?: string; fontWeight?: string }>(), {fontSize: 12,color: '#B3B3B3',fontWeight: 'bold'
})const indicator = computed(() => {const icon = props.svg ?? Loading3QuartersOutlinedreturn h(icon, {style: {fontSize: `${props.fontSize}px`,fontWeight: props.fontWeight,color: props.color},spin: true})
})
</script>

3.搞不懂,commonLoading是基于ASpin写的,去看看官网怎么写的,结果去官网看了。总结就是直接赋值

4.那我不用computed直接赋值是不是也可以呢?试了一下,还真可以

<template><!-- 加载中 --><ASpin :indicator="indicator"></ASpin>
</template>
<script lang="ts" setup>
import { Loading3QuartersOutlined } from '@ant-design/icons-vue'
const props = withDefaults(defineProps<{ fontSize?: number; svg?: any; color?: string; fontWeight?: string }>(), {fontSize: 12,color: '#B3B3B3',fontWeight: 'bold'
})const indicator = ref()
function initIndicator() {const icon = props.svg ?? Loading3QuartersOutlinedindicator.value = h(icon, {style: {fontSize: `${props.fontSize}px`,fontWeight: props.fontWeight,color: props.color},spin: true})
}
initIndicator()
</script>

5. 但是我真的不了解呀,为啥用 computed就无法正常卸载。DeepSeek还让我自己写动画来着,然后并没有用。用computed必定会报错@~~@,看不懂

三、总结

1. 遇到报错 组件没有正常卸载 unmountComponent,Cannot read properties of null (reading 'insertBefore')时,定位到具体的代码,要着重看 报错行包裹的代码!!!

不要像我一样,疏忽大意,只想着外面的代码有问题🤣

2.现确认自己的逻辑是否有问题

3.如果确认自己的逻辑没有问题。需要着重注意 二次封装的第三方组件有没有问题。尝试注释排除法找到具体的错误位置,再到官网找到具体的例子照着写

4.不过我是真搞不懂为啥 computed会导致Aspin组件无法正常卸载。有大佬知道,欢迎评论,谢谢!

/*

希望对你有帮助!

如有错误,欢迎指正!

*/

http://www.lryc.cn/news/585282.html

相关文章:

  • map数据结构在Golang中是无序的,并且键值对的查找效率较高的原因
  • 一些有意思的Python语法特性
  • pytorch的介绍以及张量的创建
  • 企业培训笔记:Vue3前端框架配置
  • mac电脑的usr/libexec目录是干什么的?
  • 怎么处理多源异构数据?搞不清楚就别谈数据融合!
  • Linux的基础I/O
  • PDF 转图助手 PDF2JPG 绿色版:免安装直接用,急处理文件的救急小天使
  • Genus:设计信息结构以及导航方式(路径种类)
  • 牛客 —— JZ22 链表中倒数最后k个结点
  • cesium添加原生MVT矢量瓦片方案
  • 云暴露面分析完整指南
  • 香港站群服务器8C/4C/2C/1C有什么区别
  • Elasticsearch混合搜索深度解析(上):问题发现与源码探索
  • C++11中的std::minmax与std::minmax_element:原理解析与实战
  • 12. 说一下 https 的加密过程
  • 笔记 | 理解C/汇编中的数组元素访问
  • 飞算JavaAI:给Java开发装上“智能引擎”的超级助手
  • UNet改进(21):门控注意力机制在UNet中的应用与优化
  • 前端高频面试题深度解析(JavaScript + Vue + jQuery)
  • 云蝠智能 VoiceAgent重构企业呼入场景服务范式
  • SpringCloud云间剑歌 第一章:云间阁现,群雄并起
  • 智能运维管理平台:AI赋能的数字化转型引擎
  • DNS(Domain Name System,域名系统)
  • java底层的native和沙箱安全机制
  • JavaScript加强篇——第四章 日期对象与DOM节点(基础)
  • 如何批量旋转视频90度?
  • 【DataFlow】数据合成流水线工具
  • Neo4j启动
  • 将手工建模模型(fbx、obj)转换为3dtiles的免费工具!