我正在创建一个基于javascript的html仪表板。为了刷新仪表板图表中的值,我编写了以下代码:
var chart, options;
function loadDynamicData() {
var data = window.parent.getDynamicData();
var dataArray = data.split(',');
for(var i = 0; i < chartData.length; i++) {
chartData[i].data.pop();
chartData[i].data.push(parseInt(dataArray[i],10));
}
}
$(document).ready(function() {
//initialize options here
setInterval(function () {
loadDynamicValues(); // loads dynamic values through ajax
// and updates options
chart = new Highcharts.Chart(options);
}, 300000);
});
但问题是当我在浏览器中运行这个很长时间(大约1小时)时,正在使用的内存会上升并且浏览器会无法响应。如果我删除setInterval()
方法并运行一次内部代码,则没有问题。
这里有什么问题?
答案 0 :(得分:3)
请在创建新图表之前先执行chart.destroy()。
if(chart)chart.destroy;
这是测试链接。 http://www.highcharts.com/tests/?file=memory-chart-destroy