setInterval()方法中的内存泄漏

时间:2012-12-13 08:19:28

标签: javascript html memory-leaks highcharts setinterval

我正在创建一个基于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()方法并运行一次内部代码,则没有问题。

这里有什么问题?

1 个答案:

答案 0 :(得分:3)

请在创建新图表之前先执行chart.destroy()。

  

if(chart)chart.destroy;

这是测试链接。 http://www.highcharts.com/tests/?file=memory-chart-destroy