动态改变echarts图表时,先销毁实例再创建图表,减少占用内内存

 关键点:

myChart.clear();//清空当前实例,会移除实例中所有的组件和图表
myChart.dispose();//销毁实例,实例销毁后无法再被使用

<!DOCTYPE html>
<html style="height: 100%">
    <head>
        <meta charset="utf-8">
		<style>
			.change{
				height: 50px;
				width: 100px;
				line-height: 50px;
				background: blue;
				text-align: center;
				color: #fff;
				border-radius: 10px;
			}
		</style>
    </head>
    <body style="width:500px;height500px;margin: auto">
		<div class="change" onclick="changeChart(this)">改变图表</div>
        <div id="container" style="width:500px;height:400px;"></div>
			
        <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/echarts@5.2.2/dist/echarts.min.js"></script>
        <script type="text/javascript">
			var data1=[150, 230, 224, 218, 135, 147, 260];
			var data2=[150, 150, 150, 150, 150, 150, 150];
			initCHART(data1);
			//绘制表格
			function initCHART(data){
				var dom = document.getElementById("container");
				var myChart = echarts.init(dom);
				var app = {};
				var option;
				option = {
				  xAxis: {
					type: 'category',
					data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
				  },
				  yAxis: {
					type: 'value'
				  },
				  series: [
					{
					  data: data,
					  type: 'line'
					}
				  ]
				};
				if (option && typeof option === 'object') {
					myChart.setOption(option);
				}
			}
			// 切换表格
			function changeChart(ele) {
				var dom = document.getElementById("container");
				var myChart = echarts.init(dom);
				myChart.clear();//清空当前实例,会移除实例中所有的组件和图表
				myChart.dispose();//销毁实例,实例销毁后无法再被使用
				initCHART(data2);
				console.log("myChart=====",myChart);
			}

        </script>
    </body>
</html>
    

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

佛佛ง

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值