uniapp APP端,echarts显示不出来,报“Initialize failed: invalid dom“错误

调试安卓手机,浏览器可以显示出来,安卓手机一直显示不出来,使用的render.js,还是显示不出来

解决:

  1. 报 "Initialize failed: invalid dom"错误;在initEcharts函数中添加了 setTimeout函数,解决了这个报错
  2. 解决了问题1后,安卓手机还是展示不出,报出这个警告: [WARNING] :Can't get DOM width or height.;加了行内样式高度
  3. 以上步骤,就显示出来了
<view
            :prop="option"
            :change:prop="echarts.updateEcharts"
            id="echarts"
            class="echarts"
            style="height:200px"
          ></view>

<script module="echarts" lang="renderjs">
	let myChart
	export default {
		mounted() {
			if (typeof window.echarts === 'function') {
				this.initEcharts()
			} else {
				// 动态引入较大类库避免影响页面展示
				const script = document.createElement('script')
				// view 层的页面运行在 www 根目录,其相对路径相对于 www 计算
				script.src = 'static/echarts.js'
				script.onload = this.initEcharts.bind(this)
				document.head.appendChild(script)
			}
       
		},
		methods: {
			initEcharts() {
        setTimeout(() => {
          myChart = echarts.init(document.getElementById('echarts'))
          // 观测更新的数据在 view 层可以直接访问到
          myChart.setOption(this.option)
        })
        // 这里是用于窗口变化时的自适应,利用的是echarts自带的resize方法
        window.addEventListener('resize', () => {
            myChart.resize()
        });
				
			},
			updateEcharts(newValue, oldValue, ownerInstance, instance) {
				// 监听 service 层数据变更
        if(myChart) {
          myChart.setOption(newValue)
          window.addEventListener('resize', () => {
              myChart.resize()
          });
        }
			},
			onClick(event, ownerInstance) {
				// 调用 service 层的方法
				ownerInstance.callMethod('onViewClick', {
					test: 'test'
				})
			}
		}
	}
</script>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值