Merge pull request #3420 from elemoine/leaks
Unregister viewport size listener on setTarget(null)
This commit is contained in:
@@ -338,13 +338,17 @@ ol.Map = function(options) {
|
||||
this.registerDisposable(this.renderer_);
|
||||
|
||||
/**
|
||||
* @type {goog.dom.ViewportSizeMonitor}
|
||||
* @private
|
||||
*/
|
||||
this.viewportSizeMonitor_ = new goog.dom.ViewportSizeMonitor();
|
||||
this.registerDisposable(this.viewportSizeMonitor_);
|
||||
|
||||
goog.events.listen(this.viewportSizeMonitor_, goog.events.EventType.RESIZE,
|
||||
this.updateSize, false, this);
|
||||
/**
|
||||
* @type {goog.events.Key}
|
||||
* @private
|
||||
*/
|
||||
this.viewportResizeListenerKey_ = null;
|
||||
|
||||
/**
|
||||
* @private
|
||||
@@ -1032,12 +1036,22 @@ ol.Map.prototype.handleTargetChanged_ = function() {
|
||||
|
||||
if (goog.isNull(targetElement)) {
|
||||
goog.dom.removeNode(this.viewport_);
|
||||
if (!goog.isNull(this.viewportResizeListenerKey_)) {
|
||||
goog.events.unlistenByKey(this.viewportResizeListenerKey_);
|
||||
this.viewportResizeListenerKey_ = null;
|
||||
}
|
||||
} else {
|
||||
goog.dom.appendChild(targetElement, this.viewport_);
|
||||
|
||||
var keyboardEventTarget = goog.isNull(this.keyboardEventTarget_) ?
|
||||
targetElement : this.keyboardEventTarget_;
|
||||
this.keyHandler_.attach(keyboardEventTarget);
|
||||
|
||||
if (goog.isNull(this.viewportResizeListenerKey_)) {
|
||||
this.viewportResizeListenerKey_ = goog.events.listen(
|
||||
this.viewportSizeMonitor_, goog.events.EventType.RESIZE,
|
||||
this.updateSize, false, this);
|
||||
}
|
||||
}
|
||||
|
||||
this.updateSize();
|
||||
|
||||
@@ -76,6 +76,8 @@ ol.TileQueue.prototype.handleTileChange = function(event) {
|
||||
var state = tile.getState();
|
||||
if (state === ol.TileState.LOADED || state === ol.TileState.ERROR ||
|
||||
state === ol.TileState.EMPTY) {
|
||||
goog.events.unlisten(tile, goog.events.EventType.CHANGE,
|
||||
this.handleTileChange, false, this);
|
||||
--this.tilesLoading_;
|
||||
this.tileChangeCallback_();
|
||||
}
|
||||
|
||||
@@ -187,6 +187,39 @@ describe('ol.Map', function() {
|
||||
});
|
||||
});
|
||||
|
||||
describe('#setTarget', function() {
|
||||
var map;
|
||||
|
||||
beforeEach(function() {
|
||||
map = new ol.Map({
|
||||
target: document.createElement('div')
|
||||
});
|
||||
var viewportResizeListeners = map.viewportSizeMonitor_.getListeners(
|
||||
goog.events.EventType.RESIZE, false);
|
||||
expect(viewportResizeListeners).to.have.length(1);
|
||||
});
|
||||
|
||||
describe('call setTarget with null', function() {
|
||||
it('unregisters the viewport resize listener', function() {
|
||||
map.setTarget(null);
|
||||
var viewportResizeListeners = map.viewportSizeMonitor_.getListeners(
|
||||
goog.events.EventType.RESIZE, false);
|
||||
expect(viewportResizeListeners).to.have.length(0);
|
||||
});
|
||||
});
|
||||
|
||||
describe('call setTarget with an element', function() {
|
||||
it('registers a viewport resize listener', function() {
|
||||
map.setTarget(null);
|
||||
map.setTarget(document.createElement('div'));
|
||||
var viewportResizeListeners = map.viewportSizeMonitor_.getListeners(
|
||||
goog.events.EventType.RESIZE, false);
|
||||
expect(viewportResizeListeners).to.have.length(1);
|
||||
});
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
describe('create interactions', function() {
|
||||
|
||||
var options;
|
||||
@@ -244,6 +277,7 @@ describe('ol.Map', function() {
|
||||
|
||||
goog.require('goog.dispose');
|
||||
goog.require('goog.dom');
|
||||
goog.require('goog.events.EventType');
|
||||
goog.require('ol.Map');
|
||||
goog.require('ol.MapEvent');
|
||||
goog.require('ol.View');
|
||||
|
||||
Reference in New Issue
Block a user