2016-09-28 1 views
0

У меня есть некоторые вопросы, касающиеся утечки памяти. Пожалуйста, обратите внимание на этот блок кода:jQuery, проблемы с памятью кендо

(function ($) { 

$.fn.bnftWindow = function (options) { 

    // Default Settings 
    var settings = $.extend({ 
    }, options); 

    // Validate parameters 
    if (settings.id === undefined || settings.id === null || settings.id === "") { 
     throw "bnftWindow id option is undefined, null or empty string"; 
    } 


    // If window container div already exists 
    if ($("#" + settings.id).length) { 
     alert("bnftWindow id already exists - will be destroyed and recreated"); 
     // destroy window container div 
     $("#" + settings.id).remove(); 
    } 

    // create window container div 
    $("body").append("<div id='" + settings.id + "'></div>"); 

    var currentInstance = $("#" + settings.id); 

    return currentInstance.each(function() { 

     currentInstance.data("bnftWindow", currentInstance); 

     var widgetId = currentInstance[0].id; //The id of the html element used to create the bnft widget 

     // Apply settings 
     $('#' + widgetId).kendoWindow(
      settings 
     ); 

     var dialog = $('#' + widgetId).data("kendoWindow"); 

     currentInstance.destroy = function() { 


      kendo.destroy($("#" + widgetId)); 

      $("#" + settings.id).remove(); 
     } 
    }); 



    function onRefresh(e) { 

     // Always center window first 
     if (settings.refresh !== undefined) { 
      settings.refresh(e); 
     } 

     var dialog = $("#" + settings.id).data("kendoWindow"); 
     dialog.center(); 
    } 
}; 

}(jQuery)); 

И этот блок кода:

function Test() 
{ 
    var element = $("#myElement"); 
    element.hide(); 
    var that = this; 

    this.ids = { 
     grid: "messagesGrid", 
     gridButton: "gridButton", 
     composeWnd: "composeWnd" 
    }; 

    this.grid = null; // will store the grid later 


     $("#" + this.ids.gridButton).on("click", function() { 
      try { 
        // Do something.... 
        that.init(); 
       } 
      } 
      catch (ex) { 
       alert("Error: " + ex); 
      } 
     }); 

} 

Test.prototype.init = function() 
{ 
    // Do something else... 
    var that = this; 

    setTimeout(function() { 
     that.createWidget(); 
    }, 500); 
} 

Test.prototype.createWidget = function() 
{ 
    // Do something else... 
    $("#grid").kendoGrid({ // Some properties here }); 

    // store grid 
    this.grid = $("#grid").data("kendoGrid"); 
    // Blah blah blah 
} 
  1. ли переменные currentInstance, идентификатор виджета, диалоговые, элемент, что, это. сетью или обработчиком событий, вызывающим утечки памяти?

  2. Если переменная элемента вызывает утечку памяти, это $ ("# myElement"). Hide(); решение? (помимо установки переменной элемента null после скрыть).

Благодарим вас заблаговременно.

+0

Пробовали ли вы делать Timeline записи с помощью Инструментов разработчика Chrome? Это поможет вам легко увидеть, есть ли утечка. Вы можете проверить [это видео] (https://youtu.be/LaxbdIyBkL0?t=236) на примере рабочего процесса для отслеживания утечек памяти. – Corina

ответ

0

Следующие работы для меня, чтобы очистить диалоговые экземпляры:

_create: function() {   
     var that = this; 
     ...  
     that.frmElement = that.wrapper.kendoWindow({ 
      ... 
      close: function (e) { 
       this.destroy(); 
       that.wrapper.remove("#" + that.options.dialogId); 
       that.wrapper.empty(); 
      } 
      ... 
     }).data("kendoWindow"); 
    }