X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=_source%2Fcore%2Fdom%2Fdomobject.js;h=fccad5d59a00e998312de5de3c2fd41f7864ffb7;hb=3fe9cac293e090ea459a3ee10d78cbe9e1dd0e03;hp=bb029e0a8764e40664a7a9542a897ee842d3bb80;hpb=039a051ccf3901311661022a30afd60fc38130c9;p=ckeditor.git diff --git a/_source/core/dom/domobject.js b/_source/core/dom/domobject.js index bb029e0..fccad5d 100644 --- a/_source/core/dom/domobject.js +++ b/_source/core/dom/domobject.js @@ -1,5 +1,5 @@ /* -Copyright (c) 2003-2010, CKSource - Frederico Knabben. All rights reserved. +Copyright (c) 2003-2013, CKSource - Frederico Knabben. All rights reserved. For licensing, see LICENSE.html or http://ckeditor.com/license */ @@ -84,10 +84,10 @@ CKEDITOR.dom.domObject.prototype = (function() { var listener = nativeListeners[ eventName ] = getNativeListener( this, eventName ); - if ( this.$.attachEvent ) - this.$.attachEvent( 'on' + eventName, listener ); - else if ( this.$.addEventListener ) + if ( this.$.addEventListener ) this.$.addEventListener( eventName, listener, !!CKEDITOR.event.useCapture ); + else if ( this.$.attachEvent ) + this.$.attachEvent( 'on' + eventName, listener ); } // Call the original implementation. @@ -107,10 +107,10 @@ CKEDITOR.dom.domObject.prototype = (function() var listener = nativeListeners && nativeListeners[ eventName ]; if ( listener ) { - if ( this.$.detachEvent ) - this.$.detachEvent( 'on' + eventName, listener ); - else if ( this.$.removeEventListener ) + if ( this.$.removeEventListener ) this.$.removeEventListener( eventName, listener, false ); + else if ( this.$.detachEvent ) + this.$.detachEvent( 'on' + eventName, listener ); delete nativeListeners[ eventName ]; } @@ -167,6 +167,9 @@ CKEDITOR.dom.domObject.prototype = (function() /** * Sets a data slot value for this object. These values are shared by all * instances pointing to that same DOM object. + * Note: The created data slot is only guarantied to be available on this unique dom node, + * thus any wish to continue access it from other element clones (either created by clone node or from innerHtml) + * will fail, for such usage, please use {@link CKEDITOR.dom.element::setAttribute} instead. * @name CKEDITOR.dom.domObject.prototype.setCustomData * @function * @param {String} key A key used to identify the data slot. @@ -200,7 +203,7 @@ CKEDITOR.dom.domObject.prototype = (function() */ domObjectProto.getCustomData = function( key ) { - var expandoNumber = this.$._cke_expando, + var expandoNumber = this.$[ 'data-cke-expando' ], dataSlot = expandoNumber && customData[ expandoNumber ]; return dataSlot && dataSlot[ key ]; @@ -211,7 +214,7 @@ CKEDITOR.dom.domObject.prototype = (function() */ domObjectProto.removeCustomData = function( key ) { - var expandoNumber = this.$._cke_expando, + var expandoNumber = this.$[ 'data-cke-expando' ], dataSlot = expandoNumber && customData[ expandoNumber ], retval = dataSlot && dataSlot[ key ]; @@ -233,7 +236,7 @@ CKEDITOR.dom.domObject.prototype = (function() // Clear all event listeners this.removeAllListeners(); - var expandoNumber = this.$._cke_expando; + var expandoNumber = this.$[ 'data-cke-expando' ]; expandoNumber && delete customData[ expandoNumber ]; }; @@ -246,7 +249,7 @@ CKEDITOR.dom.domObject.prototype = (function() */ domObjectProto.getUniqueId = function() { - return this.$._cke_expando || ( this.$._cke_expando = CKEDITOR.tools.getNextNumber() ); + return this.$[ 'data-cke-expando' ] || ( this.$[ 'data-cke-expando' ] = CKEDITOR.tools.getNextNumber() ); }; // Implement CKEDITOR.event.