утечка памяти в JavaScript - PullRequest
0 голосов
/ 14 сентября 2009

Я пытаюсь решить проблему с утечкой памяти в IE с помощью Javascript. Basicaaly Я использую JavaScript, чтобы добавить значки поверх изображения, то мне нужно периодически обновлять значки, удаляя их и повторно добавляя их. Когда я запускаю приложение через капельницу (инструмент индикации использования памяти IE6), когда я удаляю изображения перед перерисовкой, память никогда не восстанавливается У кого-нибудь есть идеи о том, как заставить его вернуть эту память?

код ниже - periodicalExecuter является механизмом синхронизации от Prototype:

<code><pre>
<head>
    <script src="Prototype/prototype-1.6.0.3.js" type="text/javascript"></script> 
    <style> 
        #container {
            position:absolute;
            left:20px;
            top: 20px;
            height:700px;
            width:700px;
            background-color: pink;
        }
    </style> 
    <script> 
        function addIcons() {
            var ctr = document.getElementById("container");
            var x = 0;
            var y = 0;             
            var x1 = 0;
            var y1 = 0;
            var cnt = 0;
            var imgStr = "";     
            var img; 
            var div1;      
            new PeriodicalExecuter(function(pex) {
                y1 = cnt % 13;
                if (y1 == 0) {
                    x1++;
                }
                x = (x1 + 1) * 21;
                y = (y1 + 1) * 21;    
                div1 = document.createElement('div');                
                div1.id = 'img_' + (x1 - 1).toString() + y1.toString();
                div1.style.position = "absolute";
                div1.style.left = x;
                div1.style.top = y;
                img = document.createElement ('img');
                img.src = 'traffic_icons/traffic-05.gif';                
                div1.appendChild(img);
                ctr.appendChild(div1);
                cnt++;
                if (cnt == 169) {
                    pex.stop();
                    deleteIcons();
                }
            }, 0.1);
        }


        function deleteIcons() {
            var ctr = document.getElementById("container");

            var node = ""; 
            var id = "";           
            for (var k = 0; k < 13; k++) {
                for (var i = 0; i < 13; i++) {                                               
                    id = 'img_' + k.toString() + i.toString();
                    node = document.getElementById(id);        
                    ctr.removeChild(node);                    
                }
            }
            addIcons();
        }
     </script> 
</head> 

<body> 
<div id="container"></div> 
<button onclick="addIcons();" style="position:absolute;left:780px;top:20px">Load Images</button> 
 <button onclick="deleteIcons();" style="position:absolute;left:780px;top:100px">Delete Images</button>
</body> 
</html> 

Ответы [ 2 ]

1 голос
/ 14 сентября 2009

Вы можете попробовать обновить изображения, динамически изменив URL изображения, например:

var imageRefreshCounter = 0;

function refreshIcons() {
            var ctr = document.getElementById("container");

            var node = ""; 
            var id = "";           
            for (var k = 0; k < 13; k++) {
                for (var i = 0; i < 13; i++) {                                               
                    id = 'img_' + k.toString() + i.toString();
                    node = document.getElementById(id);        
                    node.src = node.src + "?" + imageRefreshCounter++;                   
                }
            }
            addIcons();
        }
0 голосов
/ 14 сентября 2009

Вам следует обновить систему до версии 1.6.1, которая устраняет некоторые утечки в самом Prototype.js.

...