在使用JavaScript更新画布时,如何避免分离的HTMLCanvase元素?
所以我的问题是,当我用chart.js库创建的折线图周期性地更新HTML中的canvas元素时,我得到了一堆分离的HTMLCAvase元素。我在修复代码中的一些内存泄漏时注意到了这一点,这些泄漏导致我的网页崩溃(chrome给出了“aw snap”错误页面)。 我能够修复大部分内存泄漏,但这一次仍然困扰着我,我很无助,因为我不知道为什么会发生这种情况 我的HTML代码中有如下画布元素:在使用JavaScript更新画布时,如何避免分离的HTMLCanvase元素?,javascript,canvas,memory-leaks,chart.js,Javascript,Canvas,Memory Leaks,Chart.js,所以我的问题是,当我用chart.js库创建的折线图周期性地更新HTML中的canvas元素时,我得到了一堆分离的HTMLCAvase元素。我在修复代码中的一些内存泄漏时注意到了这一点,这些泄漏导致我的网页崩溃(chrome给出了“aw snap”错误页面)。 我能够修复大部分内存泄漏,但这一次仍然困扰着我,我很无助,因为我不知道为什么会发生这种情况 我的HTML代码中有如下画布元素: <div class="kuvaaja"><canvas id="etaisyyskuvaa
<div class="kuvaaja"><canvas id="etaisyyskuvaaja"></canvas></div>
<div class="kuvaaja"><canvas id="etaisyyskuvaaja2"></canvas></div>
<div class="kuvaaja"><canvas id="etaisyyskuvaaja3"></canvas></div>
<div class="kuvaaja"><canvas id="etaisyyskuvaaja4"></canvas></div>
然后我开始循环更新这些画布(也在window.onload内):
在这些函数中,我首先像这样从数据库中获取数据(haepainemittaukset()与此类似,只是获取了不同的数据):
所以我想我在这里要做的是设置画布的高度和宽度,然后我在旧画布的同一画布上创建新图表。然而,看起来好像有什么地方出了问题,我当前的代码正在创建一堆分离的画布元素,但我不明白这到底是为什么发生的,在哪里发生的?所以现在我的页面的内存占用在每个周期(画布更新)后都在缓慢增加
下面是内存分布的快照:
在此内存分布中,有许多分离的画布元素都指向这些画布(pohjacanvas、pohjacanvas2、pohjacanvas3、pohjacanvas4)。您应该跟踪(例如,在数组中)以前创建的图表,然后从服务器获取新数据时,您需要检索要更新的图表,更新其数据和/或选项,然后调用
chart.update();
刷新图表。在这种情况下,您不会在每次更新时创建新图表。
您可以在中找到更多详细信息。太棒了,谢谢!使用chart.update()我能够更新我的旧图表并摆脱一堆旧图表。在Chart.js文档中有一些示例,其中数据是推式和拉式的,但也可以直接更改数据集中的数据,如下图所示
paivitysvali = setInterval(haeetaisyysmittaukset, 1000);
painepaivitys = setInterval(haepainemittaukset, 1000);
function haeetaisyysmittaukset() {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function () {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
etaisyys = [];
ajat = [];
var mittaukset = JSON.parse(xmlhttp.response);
for (var i = 0; i < mittaukset.length; i++) {
etaisyys.push(mittaukset[i]["etaisyys"]);
ajat.push(mittaukset[i]["timestamp"]);
}
if (paivitysbitti == 1) {
etaisyys.reverse();
ajat.reverse();
luokuvaaja2(pohjacanvas, etaisyys, ajat);
luokuvaaja2(pohjacanvas4, etaisyys, ajat);
}
}
}
xmlhttp.open("POST", "haeetaisyysmittaukset.php", true);
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlhttp.send("limit=" + mittausmaara);
}
function luokuvaaja2(pohja, data, ajat) {
pohja.height = 400;
pohja.width = 700;
myChart = new Chart(pohja, {
type: 'line',
data: {
labels: ajat,
datasets: [{
data: data,
label: "Etaisyys",
borderColor: "blue",
fill: false
}
]
},
options: {
animation: {
duration: 0, // general animation time
},
hover: {
animationDuration: 0, // duration of animations when hovering an item
},
title: {
display: true,
text: 'Etaisyysmittaus'
},
scales: {
yAxes: [{
ticks: {
min: 0,
max: 6000
}
}]
}
}
});
}
chart.update();