调试安卓手机,浏览器可以显示出来,安卓手机一直显示不出来,使用的render.js,还是显示不出来
解决:
- 报 "Initialize failed: invalid dom"错误;在initEcharts函数中添加了 setTimeout函数,解决了这个报错
- 解决了问题1后,安卓手机还是展示不出,报出这个警告: [WARNING] :Can't get DOM width or height.;加了行内样式高度
- 以上步骤,就显示出来了
<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>