From 70f12229679ef5a7b0143e8eae50af69c19270ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Karl=20Syvert=20L=C3=B8land?= Date: Thu, 17 Sep 2015 13:31:05 +0200 Subject: [PATCH] Fixed memory leak. Detached dom was retained my mousedown event forever --- js/bootstrap-datetimepicker.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/js/bootstrap-datetimepicker.js b/js/bootstrap-datetimepicker.js index b244f432..7c35e222 100644 --- a/js/bootstrap-datetimepicker.js +++ b/js/bootstrap-datetimepicker.js @@ -108,6 +108,13 @@ this._attachEvents(); + this.clickedOutside = function (e) { + // Clicked outside the datetimepicker, hide it + if ($(e.target).closest('.datetimepicker').length === 0) { + that.hide(); + } + } + this.formatViewType = 'datetime'; if ('formatViewType' in options) { this.formatViewType = options.formatViewType; @@ -211,12 +218,8 @@ var selector = this.bootcssVer === 3 ? '.prev span, .next span' : '.prev i, .next i'; this.picker.find(selector).toggleClass(this.icons.leftArrow + ' ' + this.icons.rightArrow); } - $(document).on('mousedown', function (e) { - // Clicked outside the datetimepicker, hide it - if ($(e.target).closest('.datetimepicker').length === 0) { - that.hide(); - } - }); + + $(document).on('mousedown', this.clickedOutside); this.autoclose = false; if ('autoclose' in options) { @@ -362,6 +365,7 @@ remove: function () { this._detachEvents(); + $(document).off('mousedown', this.clickedOutside); this.picker.remove(); delete this.picker; delete this.element.data().datetimepicker;