vue jsx Cannot read property ‘__asyncLoader‘ of undefined

文章讨论了在使用Vue.js和tsx时遇到的两个TypeError。当尝试通过arr.map生成列表时,如果arr为空,会导致Cannotreadproperty__asyncLoaderofundefined的错误。另外,定义在OtherComponent组件中的computed属性在jsx中使用时,未加.value会抛出错误。解决方案是确保在jsx中引用computed属性时添加.value。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、报错1:
Uncaught (in promise) TypeError: Cannot read property '__asyncLoader' of undefined
2、报错2:
TypeError: Cannot read properties of null (reading 'emitsOptions')

使用tsx类似如下

<div>
    {arr.map(it => <OtherComponent></OtherComponent>}
</div>

通过控制arr内容自动生成列表

然而列表能正常插入dom。置空时就报上述错误。

排查

经过若干尝试(什么vue-router defineAsyncComponent均无效。)

范围缩小在OtherComponent 组件。

分块注释法排查[doge]。。。

结果

jsx中使用compouted值,没有.value

OtherComponent 示意代码

defineComponent({
    setup(){
        let a = computed(() => ...)
        return () => <div>
            { a } // 导致报错
            { a.value } // 正确
        </div>
    }
})

总结

computed 的变量,在jsx中使用时未.value 导致。

参考

  1. javascript - Day 96/100 Cannot read property '__asyncLoader' of undefined - 个人文章 - SegmentFault 思否
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值