I create elements using createElement method, and append it to some parent element. Later on, I clear the innerHTML of the parent element. Will this cause memory leak ? what happens to the element that was created ? If this is a memory leak, how to handle it?. also, if there is any callback function attached to the element, does it need to be detached ?
var spanelem = document.createElement('span');
spanelem.onclick = function(){
CallMe();
};
var parentdiv = document.getElementById('ParentCnt');
parentdiv.appendChild(spanelem);
.....
.....
parentdiv.innerHTML = " "; //is this memory Leak ? what happens to spanelem?
Memory leaks can and do happen in garbage collected languages such as JavaScript. These can go unnoticed for some time, and eventually they will wreak havoc. For this reason, memory profiling tools are essential for finding memory leaks.
A memory leak starts when a program requests a chunk of memory from the operating system for itself and its data. As a program operates, it sometimes needs more memory and makes an additional request.
Use reference objects to avoid memory leaks ref package, you can work with the garbage collector in your program. This allows you to avoid directly referencing objects and use special reference objects that the garbage collector easily clears. The special subclasses allow you to refer to objects indirectly.
It depends.
If you have code you give - spanElem still exists in memory ( if var spanelem
was in global scope, and you didn't execute spanelem = null
), cause there is accessible reference to object.
Otherwise if spanElem has the only reference from it's onClick handler - it will be memory leak only in IE8-. All modern browsers handle such cases and clean memory on garbage collection.
I suppose you mean not right the same code, but just principle -- in such case you can check if there are no other handlers which have link to spanElem in their lexical env, if so - you can just clear reference with adding
spanelem = null;
after
parentdiv.appendChild(spanelem);
Check more details at MDN
P.S. if you run next code
var spanelem = document.createElement('span');
spanelem.onclick = function(){
CallMe();
};
var parentdiv = document.getElementById('ParentCnt');
parentdiv.appendChild(spanelem);
parentdiv.innerHTML = '';
console.log(spanelem);
you'll find that spanelem still exists ( it will be the same, if you'll run
setTimeout(function(){ console.log(spanelem); }, 9999); // some huge delay here
) - but the only reason is that for code below we save reference for spanelem object so gc doesn't remove object. If we won't use it - gc will remove object on it's running
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With