Error in callback for immediate watcher “chartsData“: “Error: Initialize failed: invalid dom.“

 在使用echarts提示dom未找到,原因就是当我们封装了echarts组件初始化传值时通常会造成过早调用,也就是在数据还未处理完就已经调用init函数进行初始化,此时dom还未挂载成功,就会报这个错,这里解决可以使用nextTick()函数在初始化时延时调用;

 this.$nextTick(() => {
    this.drawChart() //初始化函数
 })

        在封装中推荐大家使用监听器来实现触发更新,这样会使你的效果最佳,也最保险,不会出现dom未生成的情况,我们通常会把一些可变的值传递给子组件,比如data,在data初始化还是空的时候我们就在编译父组件时进行了传递,子组件监听初次执行,但是不显示因为是空数据,当我们函数运行完,拿到了后台数据进行再次赋值,子组件的props同时更新,被监听到后就会再次触发渲染函数,echarts图表就正常显示了。

       

  watch: {
        // 传入的动态数据
        chartsData: {
            handler(val, oldVal) {
                this.$nextTick(() => {
                    this.drawChart()
                })
            },
            deep: true, // 深度监听
            immediate: true // 初始化执行
        }
    },

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[2\]中的错误案例一,报错信息"Error: Initialize failed: invalid dom.",这个错误是由于父组件传递给子组件的id值没有正确传递导致的。在父组件中,需要将id值用单引号包裹起来,以确保它是一个字符串类型,子组件才能正确接收。正确的示例是将:id="'numLine'",这样子组件才能正确接收id值。\[2\] 另外,根据引用\[3\]中的错误案例二,报错信息"created中元素还未挂载到页面,此时操作DOM则会报错"。这个错误是由于在created生命周期钩子中操作DOM元素,而此时元素还未挂载到页面上,所以会报错。解决这个问题的方法是将操作DOM元素的方法放在mounted生命周期钩子中调用,因为在mounted时,页面上的元素已经挂载完成。具体的解决办法是将操作元素的方法放在mounted钩子中,即将created中的代码移动到mounted中,这样就可以避免报错。\[3\] #### 引用[.reference_title] - *1* [组件内部watch后切换数据报错Error in callback for watcher “xxxx](https://blog.csdn.net/weixin_40121676/article/details/122841006)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [使用echarts报错Error: Initialize failed: invalid dom. 解决方法及详解](https://blog.csdn.net/X_Flandre/article/details/118809014)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值