echarts的初始化和销毁dispose 容器节点被销毁以及被重建时
假设页⾯中存在多个标签页,
每个标签页都包含⼀些图表。
当选中⼀个标签页的时候,其他标签页的内容在 DOM 中被移除了。
这样,当⽤户再选中这些标签页的时候,就会发现图表“不见”了。
本质上,这是由于图表的容器节点被移除导致的。
即使之后该节点被重新添加,图表所在的节点也已经不存在了。
正确的做法是,
在图表容器被销毁之后,
调⽤ echartsInstance.dispose 销毁实例,
在图表容器重新被添加后再次调⽤ echarts.init 初始化。
setoption从上⾯这⼀句话,我们可以得出⼀个结论:
那就是有些时候我们在移除容器的时候,echarts可能展⽰不出来
那么解决的办法是:
调⽤ echartsInstance.dispose 销毁实例,
echartsInstance.dispose的使⽤
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>第⼀个 ECharts 实例</title>
<!-- 引⼊ echarts.js -->
<script src="/echarts/4.3.0/echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备⼀个具备⼤⼩(宽⾼)的Dom -->
<div id="main" ></div>
<div onclick="showHander()" class="zahsnhi">展⽰实例</div>
<div onclick="desHander()" class="xiaohui">销毁实例</div>
<script type="text/javascript">
// 初始化echarts
function xuanranInt() {
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.ElementById('main'));
let index = 0;
var colorList = ['#73DDFF', '#73ACFF', '#FDD56A', '#FDB36A', '#FD866A', '#9E87FF', '#58D5FF'];
var data = [{
'name': '热点⽹格',
'value': 5600
}, {
'name': '⼤⽓污染',
'value': 3600
}, {
'name': '⽔质超标',
'value': 1500
}, {
'name': '在线超标',
'value': 2000
}, {
'name': '未知',
'value': 899
}, {
'name': '系统对接',
'value': 4000
}]
option = {
title: {
text: 'PieChart',
x: 'center',
y: 'center',
textStyle: {
fontSize: 20
}
},
tooltip: {
trigger: 'item'
},
legend: {
type: 'scroll',
orient: 'vertical',
right: '5%',
top: 'center',
selectedMode: true,
icon: 'pin',
formatter: function (name) {
let title = ''
var total = 0;
var target;
var index;
for (var i = 0, l = data.length; i < l; i++) {
if (data[i].name == name) {
target = data[i].value;
title = data[i].label
index = i < 6 ? i : 5
}
}
return ` ${name} ${index} ${target}个`
}
},
label: { //去除饼图的指⽰折线label
normal: {
show: false,
position: 'inside',
formatter: "{b}:{d}%"
},
},
series: [{
type: 'pie',
center: ['50%', '50%'],
radius: ['50%', '70%'],
clockwise: true,
avoidLabelOverlap: true,
hoverOffset: 30,
emphasis: {
itemStyle: {
borderColor: '#f3f3f3',
borderWidth: 10
}
},
itemStyle: {
normal: {
borderColor: "#FFFFFF",
borderWidth: 1,
label: {
show: false,
},
labelLine: {
show: false
}
}
},
data: data,
}]
};
// 使⽤刚指定的配置项和数据显⽰图表。
myChart.setOption(option);
}
// 调⽤
xuanranInt();
// 重新渲染echarts
function showHander() {
xuanranInt();
}
// 销毁实例
function desHander() {
var myChart = echarts.ElementById('main'));
// 销毁实例,销毁后实例⽆法再被使⽤。
// 在什么情况下需要调⽤该函数进⾏销毁当前的实例呢?
// 官⽅给的说明:在图表容器被销毁之后,调⽤ echartsInstance.dispose 销毁实例, myChart.dispose();
}
</script>
</body>
</html>
效果图
echartsInstance.clear的使⽤
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>第⼀个 ECharts 实例</title>
<!-- 引⼊ echarts.js -->
<script src="/echarts/4.3.0/echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备⼀个具备⼤⼩(宽⾼)的Dom -->
<div id="main" ></div>
<div onclick="showHander()">展⽰实例</div>
<div onclick="desHander()">销毁实例</div>
<div onclick="qingkong()">清空当前实例</div>
<script type="text/javascript">
// 初始化echarts
function xuanranInt(){
// 基于准备好的dom,初始化echarts实例
var myChart = echarts.ElementById('main'));
let index = 0;
var colorList = ['#73DDFF', '#73ACFF', '#FDD56A', '#FDB36A', '#FD866A', '#9E87FF', '#58D5FF']; var data = [{
'name': '热点⽹格',
'value': 5600
}, {
'name': '⼤⽓污染',
'value': 3600
}, {
'name': '⽔质超标',
'value': 1500
}, {
'name': '在线超标',
'value': 2000
}, {
'name': '未知',
'value': 899
}, {
'name': '系统对接',
'value': 4000
}]
option = {
title: {
text: 'PieChart',
x: 'center',
y: 'center',
textStyle: {
fontSize: 20
}
},
tooltip: {
trigger: 'item'
},
legend: {
type: 'scroll',
orient: 'vertical',
right: '5%',
top: 'center',
selectedMode: true,
icon: 'pin',
formatter: function (name) {
let title = ''
var total = 0;
var target;
var index;
for (var i = 0, l = data.length; i < l; i++) {
if (data[i].name == name) {
target = data[i].value;
title = data[i].label
index = i < 6 ? i : 5
}
}
return ` ${name} ${index} ${target}个`
}
},
label: { //去除饼图的指⽰折线label
normal: {
show: false,
position: 'inside',
formatter: "{b}:{d}%"
},
},
series: [{
type: 'pie',
center: ['50%', '50%'],
radius: ['50%', '70%'],
clockwise: true,
avoidLabelOverlap: true,
hoverOffset: 30,
emphasis: {
itemStyle: {
borderColor: '#f3f3f3',
borderWidth: 10
}
},
itemStyle: {
normal: {
borderColor: "#FFFFFF",
borderWidth: 1,
label: {
show: false,
},
labelLine: {
show: false
}
}
},
data: data,
}]
};
/
/ 使⽤刚指定的配置项和数据显⽰图表。
myChart.setOption(option);
}
// 调⽤
xuanranInt();
// 重新渲染echarts
function showHander(){
xuanranInt();
}
// 销毁实例
function desHander(){
var myChart = echarts.ElementById('main'));
// 销毁实例,销毁后实例⽆法再被使⽤。
// 在什么情况下需要调⽤该函数进⾏销毁当前的实例呢?
// 官⽅给的说明:在图表容器被销毁之后,调⽤ echartsInstance.dispose 销毁实例, myChart.dispose();
}
// 清空当前实例
function qingkong(){
// 清空当前实例,会移除实例中所有的组件和图表。
var myChart = echarts.ElementById('main'));
myChart.clear()
}
</script>
</body>
</html>
clear和dispose的区别在哪⾥呢?
学过vue的同学都知道,v-show和v-if
其实clear类似于v-show
dispose类似于v-if
他们的区别就是这样
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论