ViewDocumentFragment
Document fragment.
To create a new document fragment instance use the ViewUpcastWriter#createDocumentFragment() method.
Properties
childCount : numberreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#childCountNumber of child nodes in this document fragment.
document : ViewDocumentreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#documentThe document to which this document fragment belongs.
getFillerOffset : undefinedreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#getFillerOffsetArtificial element getFillerOffset. Returns
undefined. Added for compatibility reasons.isEmpty : booleanreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#isEmptyIs
trueif there are no nodes inside this document fragment,falseotherwise.name : undefinedreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#nameArtificial element name. Returns
undefined. Added for compatibility reasons.parent : nullreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#parentArtificial parent of
DocumentFragment. Returnsnull. Added for compatibility reasons.root : thisreadonlymodule:engine/view/documentfragment~ViewDocumentFragment#rootArtificial root of
DocumentFragment. Returns itself. Added for compatibility reasons.module:engine/view/documentfragment~ViewDocumentFragment#_childrenArray of child nodes.
_customProperties : Map<string | symbol, unknown>privatereadonlymodule:engine/view/documentfragment~ViewDocumentFragment#_customPropertiesMap of custom properties. Custom properties can be added to document fragment instance.
Methods
constructor( document, [ children ] )internalmodule:engine/view/documentfragment~ViewDocumentFragment#constructorCreates new DocumentFragment instance.
Parameters
document : ViewDocumentThe document to which this document fragment belongs.
[ children ] : ViewNode | Iterable<ViewNode>A list of nodes to be inserted into the created document fragment.
Symbol.iterator() → Iterator<ViewNode>module:engine/view/documentfragment~ViewDocumentFragment#Symbol.iteratordelegate( events ) → EmitterMixinDelegateChaininheritedmodule:engine/view/documentfragment~ViewDocumentFragment#delegateDelegates selected events to another
Emitter. For instance:emitterA.delegate( 'eventX' ).to( emitterB ); emitterA.delegate( 'eventX', 'eventY' ).to( emitterC );Copy codethen
eventXis delegated (fired by)emitterBandemitterCalong withdata:emitterA.fire( 'eventX', data );Copy codeand
eventYis delegated (fired by)emitterCalong withdata:emitterA.fire( 'eventY', data );Copy codeParameters
events : Array<string>Event names that will be delegated to another emitter.
Returns
fire( eventOrInfo, args ) → GetEventInfo<TEvent>[ 'return' ]inheritedmodule:engine/view/documentfragment~ViewDocumentFragment#fireFires an event, executing all callbacks registered for it.
The first parameter passed to callbacks is an
EventInfoobject, followed by the optionalargsprovided in thefire()method call.Type parameters
Parameters
eventOrInfo : GetNameOrEventInfo<TEvent>The name of the event or
EventInfoobject if event is delegated.args : TEvent[ 'args' ]Additional arguments to be passed to the callbacks.
Returns
GetEventInfo<TEvent>[ 'return' ]By default the method returns
undefined. However, the return value can be changed by listeners through modification of theevt.return's property (the event info is the first param of every callback).
module:engine/view/documentfragment~ViewDocumentFragment#getChildgetChildIndex( node ) → numbermodule:engine/view/documentfragment~ViewDocumentFragment#getChildIndexGets index of the given child node. Returns
-1if child node is not found.Parameters
node : ViewNodeChild node.
Returns
numberIndex of the child node.
getChildren() → IterableIterator<ViewNode>module:engine/view/documentfragment~ViewDocumentFragment#getChildrengetCustomProperties() → Iterable<tuple>module:engine/view/documentfragment~ViewDocumentFragment#getCustomPropertiesReturns an iterator which iterates over this document fragment's custom properties. Iterator provides
[ key, value ]pairs for each stored property.Returns
Iterable<tuple>
getCustomProperty( key ) → unknownmodule:engine/view/documentfragment~ViewDocumentFragment#getCustomPropertyReturns the custom property value for the given key.
Parameters
key : string | symbol
Returns
unknown
is( type ) → this is ViewElement | ViewAttributeElement | ViewContainerElement | ViewEditableElement | ViewEmptyElement | ViewRawElement | ViewRootEditableElement | ViewUIElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ELEMENTChecks whether this object is of type
ViewElementor its subclass.element.is( 'element' ); // -> true element.is( 'node' ); // -> true element.is( 'view:element' ); // -> true element.is( 'view:node' ); // -> true element.is( 'model:element' ); // -> false element.is( 'documentSelection' ); // -> falseCopy codeAssuming that the object being checked is an element, you can also check its name:
element.is( 'element', 'img' ); // -> true if this is an <img> element text.is( 'element', 'img' ); -> falseCopy codeParameters
type : 'element' | 'view:element'
Returns
is( type ) → this is ViewAttributeElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ATTRIBUTE_ELEMENTChecks whether this object is of type
ViewAttributeElement.attributeElement.is( 'attributeElement' ); // -> true attributeElement.is( 'element' ); // -> true attributeElement.is( 'node' ); // -> true attributeElement.is( 'view:attributeElement' ); // -> true attributeElement.is( 'view:element' ); // -> true attributeElement.is( 'view:node' ); // -> true attributeElement.is( 'model:element' ); // -> false attributeElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is an attribute element, you can also check its name:
attributeElement.is( 'element', 'b' ); // -> true if this is a bold element attributeElement.is( 'attributeElement', 'b' ); // -> same as above text.is( 'element', 'b' ); -> falseCopy codeParameters
type : 'attributeElement' | 'view:attributeElement'
Returns
this is ViewAttributeElement
is( type ) → this is ViewEditableElement | ViewRootEditableElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:EDITABLE_ELEMENTChecks whether this object is of type
ViewEditableElementor its subclass.editableElement.is( 'editableElement' ); // -> true editableElement.is( 'element' ); // -> true editableElement.is( 'node' ); // -> true editableElement.is( 'view:editableElement' ); // -> true editableElement.is( 'view:element' ); // -> true editableElement.is( 'view:node' ); // -> true editableElement.is( 'model:element' ); // -> false editableElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is an editbale element, you can also check its name:
editableElement.is( 'element', 'div' ); // -> true if this is a div element editableElement.is( 'editableElement', 'div' ); // -> same as above text.is( 'element', 'div' ); -> falseCopy codeParameters
type : 'editableElement' | 'view:editableElement'
Returns
this is ViewEditableElement | ViewRootEditableElement
is( type ) → this is ViewContainerElement | ViewEditableElement | ViewRootEditableElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:CONTAINER_ELEMENTChecks whether this object is of type
ViewContainerElementor its subclass.containerElement.is( 'containerElement' ); // -> true containerElement.is( 'element' ); // -> true containerElement.is( 'node' ); // -> true containerElement.is( 'view:containerElement' ); // -> true containerElement.is( 'view:element' ); // -> true containerElement.is( 'view:node' ); // -> true containerElement.is( 'model:element' ); // -> false containerElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is a container element, you can also check its name:
containerElement.is( 'element', 'div' ); // -> true if this is a div container element containerElement.is( 'contaienrElement', 'div' ); // -> same as above text.is( 'element', 'div' ); -> falseCopy codeParameters
type : 'containerElement' | 'view:containerElement'
Returns
is( type ) → this is ViewRawElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:RAW_ELEMENTChecks whether this object is of type
ViewRawElement.rawElement.is( 'rawElement' ); // -> true rawElement.is( 'element' ); // -> true rawElement.is( 'node' ); // -> true rawElement.is( 'view:rawElement' ); // -> true rawElement.is( 'view:element' ); // -> true rawElement.is( 'view:node' ); // -> true rawElement.is( 'model:element' ); // -> false rawElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is a raw element, you can also check its name:
rawElement.is( 'img' ); // -> true if this is an img element rawElement.is( 'rawElement', 'img' ); // -> same as above text.is( 'img' ); -> falseCopy codeParameters
type : 'rawElement' | 'view:rawElement'
Returns
this is ViewRawElement
is( type ) → this is ViewDocumentFragmentinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:DOCUMENT_FRAGMENThecks whether this object is of type
ViewDocumentFragment.docFrag.is( 'documentFragment' ); // -> true docFrag.is( 'view:documentFragment' ); // -> true docFrag.is( 'model:documentFragment' ); // -> false docFrag.is( 'element' ); // -> false docFrag.is( 'node' ); // -> falseCopy codeParameters
type : 'documentFragment' | 'view:documentFragment'
Returns
this is ViewDocumentFragment
module:engine/view/documentfragment~ViewDocumentFragment#is:RANGEChecks whether this object is of type
ViewRange.range.is( 'range' ); // -> true range.is( 'view:range' ); // -> true range.is( 'model:range' ); // -> false range.is( 'element' ); // -> false range.is( 'selection' ); // -> falseCopy codeParameters
type : 'range' | 'view:range'
Returns
this is ViewRange
is( type ) → this is ViewPositioninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:POSITIONChecks whether this object is of type
ViewPosition.position.is( 'position' ); // -> true position.is( 'view:position' ); // -> true position.is( 'model:position' ); // -> false position.is( 'element' ); // -> false position.is( 'range' ); // -> falseCopy codeParameters
type : 'position' | 'view:position'
Returns
this is ViewPosition
is( type ) → this is ViewTextProxyinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:TEXT_PROXYChecks whether this object is of type
ViewTextProxy.textProxy.is( '$textProxy' ); // -> true textProxy.is( 'view:$textProxy' ); // -> true textProxy.is( 'model:$textProxy' ); // -> false textProxy.is( 'element' ); // -> false textProxy.is( 'range' ); // -> falseCopy codeNote: Until version 20.0.0 this method wasn't accepting
'$textProxy'type. The legacy'textProxy'type is still accepted for backward compatibility.Parameters
type : '$textProxy' | 'view:$textProxy'
Returns
this is ViewTextProxy
module:engine/view/documentfragment~ViewDocumentFragment#is:TEXTChecks whether this object is of type
ViewText.text.is( '$text' ); // -> true text.is( 'node' ); // -> true text.is( 'view:$text' ); // -> true text.is( 'view:node' ); // -> true text.is( 'model:$text' ); // -> false text.is( 'element' ); // -> false text.is( 'range' ); // -> falseCopy codeParameters
type : '$text' | 'view:$text'
Returns
this is ViewText
is( type ) → this is ViewUIElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:UI_ELEMENTChecks whether this object is of type
ViewUIElement.uiElement.is( 'uiElement' ); // -> true uiElement.is( 'element' ); // -> true uiElement.is( 'node' ); // -> true uiElement.is( 'view:uiElement' ); // -> true uiElement.is( 'view:element' ); // -> true uiElement.is( 'view:node' ); // -> true uiElement.is( 'model:element' ); // -> false uiElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is an ui element, you can also check its name:
uiElement.is( 'element', 'span' ); // -> true if this is a span ui element uiElement.is( 'uiElement', 'span' ); // -> same as above text.is( 'element', 'span' ); -> falseCopy codeParameters
type : 'uiElement' | 'view:uiElement'
Returns
this is ViewUIElement
is( type ) → this is ViewRootEditableElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ROOT_ELEMENTChecks whether this object is of type
ViewRootEditableElement.rootEditableElement.is( 'rootElement' ); // -> true rootEditableElement.is( 'editableElement' ); // -> true rootEditableElement.is( 'element' ); // -> true rootEditableElement.is( 'node' ); // -> true rootEditableElement.is( 'view:editableElement' ); // -> true rootEditableElement.is( 'view:element' ); // -> true rootEditableElement.is( 'view:node' ); // -> true rootEditableElement.is( 'model:element' ); // -> false rootEditableElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is a root editable element, you can also check its name:
rootEditableElement.is( 'element', 'div' ); // -> true if this is a div root editable element rootEditableElement.is( 'rootElement', 'div' ); // -> same as above text.is( 'element', 'div' ); -> falseCopy codeParameters
type : 'rootElement' | 'view:rootElement'
Returns
this is ViewRootEditableElement
is( type ) → this is ViewEmptyElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:EMPTY_ELEMENTChecks whether this object is of type
ViewEmptyElement.emptyElement.is( 'emptyElement' ); // -> true emptyElement.is( 'element' ); // -> true emptyElement.is( 'node' ); // -> true emptyElement.is( 'view:emptyElement' ); // -> true emptyElement.is( 'view:element' ); // -> true emptyElement.is( 'view:node' ); // -> true emptyElement.is( 'model:element' ); // -> false emptyElement.is( 'documentFragment' ); // -> falseCopy codeAssuming that the object being checked is an empty element, you can also check its name:
emptyElement.is( 'element', 'img' ); // -> true if this is a img element emptyElement.is( 'emptyElement', 'img' ); // -> same as above text.is( 'element', 'img' ); -> falseCopy codeParameters
type : 'emptyElement' | 'view:emptyElement'
Returns
this is ViewEmptyElement
is( type ) → this is ViewSelection | ViewDocumentSelectioninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:SELECTIONChecks whether this object is of type
ViewSelectionorViewDocumentSelection.selection.is( 'selection' ); // -> true selection.is( 'view:selection' ); // -> true selection.is( 'model:selection' ); // -> false selection.is( 'element' ); // -> false selection.is( 'range' ); // -> falseCopy codeParameters
type : 'selection' | 'view:selection'
Returns
this is ViewSelection | ViewDocumentSelection
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ELEMENT_NAMEChecks whether the object is of type
ViewElementor its subclass and has the specifiedname.Type parameters
N : extends string
Parameters
type : 'element' | 'view:element'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:CONTAINER_ELEMENT_NAMEChecks whether the object is of type
ViewContainerElementor its subclass and has the specifiedname.Type parameters
N : extends string
Parameters
type : 'containerElement' | 'view:containerElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:EMPTY_ELEMENT_NAMEChecks whether the object is of type
ViewEmptyElementhas the specifiedname.Type parameters
N : extends string
Parameters
type : 'emptyElement' | 'view:emptyElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ROOT_ELEMENT_NAMEChecks whether the object is of type
ViewRootEditableElementand has the specifiedname.Type parameters
N : extends string
Parameters
type : 'rootElement' | 'view:rootElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:UI_ELEMENT_NAMEChecks whether the object is of type
ViewUIElementand has the specifiedname.Type parameters
N : extends string
Parameters
type : 'uiElement' | 'view:uiElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:RAW_ELEMENT_NAMEChecks whether the object is of type
ViewRawElementand has the specifiedname.Type parameters
N : extends string
Parameters
type : 'rawElement' | 'view:rawElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:EDITABLE_ELEMENT_NAMEChecks whether the object is of type
ViewEditableElementor its subclass and has the specifiedname.Type parameters
N : extends string
Parameters
type : 'editableElement' | 'view:editableElement'name : N
Returns
boolean
is( type, name ) → booleaninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:ATTRIBUTE_ELEMENT_NAMEChecks whether the object is of type
ViewAttributeElementand has the specifiedname.Type parameters
N : extends string
Parameters
type : 'attributeElement' | 'view:attributeElement'name : N
Returns
boolean
is( type ) → this is ViewDocumentSelectioninheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:DOCUMENT_SELECTIONChecks whether this object is of type
ViewDocumentSelection.`docSelection.is( 'selection' ); // -> true docSelection.is( 'documentSelection' ); // -> true docSelection.is( 'view:selection' ); // -> true docSelection.is( 'view:documentSelection' ); // -> true docSelection.is( 'model:documentSelection' ); // -> false docSelection.is( 'element' ); // -> false docSelection.is( 'node' ); // -> falseCopy codeParameters
type : 'documentSelection' | 'view:documentSelection'
Returns
this is ViewDocumentSelection
is( type ) → this is ViewText | ViewNode | ViewElement | ViewAttributeElement | ViewContainerElement | ViewEditableElement | ViewEmptyElement | ViewRawElement | ViewRootEditableElement | ViewUIElementinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#is:NODEChecks whether this object is of type
ViewNodeor its subclass.This method is useful when processing view objects that are of unknown type. For example, a function may return a
ViewDocumentFragmentor aViewNodethat can be either a text node or an element. This method can be used to check what kind of object is returned.someObject.is( 'element' ); // -> true if this is an element someObject.is( 'node' ); // -> true if this is a node (a text node or an element) someObject.is( 'documentFragment' ); // -> true if this is a document fragmentCopy codeSince this method is also available on a range of model objects, you can prefix the type of the object with
model:orview:to check, for example, if this is the model's or view's element:viewElement.is( 'view:element' ); // -> true viewElement.is( 'model:element' ); // -> falseCopy codeBy using this method it is also possible to check a name of an element:
imgElement.is( 'element', 'img' ); // -> true imgElement.is( 'view:element', 'img' ); // -> same as above, but more preciseCopy codeParameters
type : 'node' | 'view:node'
Returns
listenTo( emitter, event, callback, [ options ] ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#listenTo:BASE_EMITTERRegisters a callback function to be executed when an event is fired in a specific (emitter) object.
Events can be grouped in namespaces using
:. When namespaced event is fired, it additionally fires all callbacks for that namespace.// myEmitter.on( ... ) is a shorthand for myEmitter.listenTo( myEmitter, ... ). myEmitter.on( 'myGroup', genericCallback ); myEmitter.on( 'myGroup:myEvent', specificCallback ); // genericCallback is fired. myEmitter.fire( 'myGroup' ); // both genericCallback and specificCallback are fired. myEmitter.fire( 'myGroup:myEvent' ); // genericCallback is fired even though there are no callbacks for "foo". myEmitter.fire( 'myGroup:foo' );Copy codeAn event callback can stop the event and set the return value of the
firemethod.Type parameters
Parameters
emitter : EmitterThe object that fires the event.
event : TEvent[ 'name' ]The name of the event.
callback : GetCallback<TEvent>The function to be called on event.
[ options ] : GetCallbackOptions<TEvent>Additional options.
Returns
void
off( event, callback ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#offStops executing the callback on the given event. Shorthand for
this.stopListening( this, event, callback ).Parameters
event : stringThe name of the event.
callback : FunctionThe function to stop being called.
Returns
void
on( event, callback, [ options ] ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#onRegisters a callback function to be executed when an event is fired.
Shorthand for
this.listenTo( this, event, callback, options )(it makes the emitter listen on itself).Type parameters
Parameters
event : TEvent[ 'name' ]The name of the event.
callback : GetCallback<TEvent>The function to be called on event.
[ options ] : GetCallbackOptions<TEvent>Additional options.
Returns
void
once( event, callback, [ options ] ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#onceRegisters a callback function to be executed on the next time the event is fired only. This is similar to calling
onfollowed byoffin the callback.Type parameters
Parameters
event : TEvent[ 'name' ]The name of the event.
callback : GetCallback<TEvent>The function to be called on event.
[ options ] : GetCallbackOptions<TEvent>Additional options.
Returns
void
stopDelegating( [ event ], [ emitter ] ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#stopDelegatingStops delegating events. It can be used at different levels:
- To stop delegating all events.
- To stop delegating a specific event to all emitters.
- To stop delegating a specific event to a specific emitter.
Parameters
[ event ] : stringThe name of the event to stop delegating. If omitted, stops it all delegations.
[ emitter ] : Emitter(requires
event) The object to stop delegating a particular event to. If omitted, stops delegation ofeventto all emitters.
Returns
void
stopListening( [ emitter ], [ event ], [ callback ] ) → voidinheritedmodule:engine/view/documentfragment~ViewDocumentFragment#stopListening:BASE_STOPStops listening for events. It can be used at different levels:
- To stop listening to a specific callback.
- To stop listening to a specific event.
- To stop listening to all events fired by a specific object.
- To stop listening to all events fired by all objects.
Parameters
[ emitter ] : EmitterThe object to stop listening to. If omitted, stops it for all objects.
[ event ] : string(Requires the
emitter) The name of the event to stop listening to. If omitted, stops it for all events fromemitter.[ callback ] : Function(Requires the
event) The function to be removed from the call list for the givenevent.
Returns
void
toJSON() → unknownmodule:engine/view/documentfragment~ViewDocumentFragment#toJSONConverts
ViewDocumentFragmentinstance to plain object and returns it. Takes care of converting all of this document fragment's children.Returns
unknownViewDocumentFragmentinstance converted to plain object.
_appendChild( items ) → numberinternalmodule:engine/view/documentfragment~ViewDocumentFragment#_appendChild_fireChange( type, node, [ data ] = { data.index } ) → voidinternalmodule:engine/view/documentfragment~ViewDocumentFragment#_fireChangeParameters
type : ViewDocumentChangeTypeType of the change.
node : ViewNode | ViewDocumentFragmentChanged node.
[ data ] : objectAdditional data.
Propertiesdata.index : number
Returns
void
Fires
_insertChild( index, items ) → numberinternalmodule:engine/view/documentfragment~ViewDocumentFragment#_insertChildInserts a child node or a list of child nodes on the given index and sets the parent of these nodes to this fragment.
Parameters
index : numberPosition where nodes should be inserted.
items : string | ViewItem | Iterable<( string | ViewItem )>Items to be inserted.
Returns
numberNumber of inserted nodes.
_removeChildren( index, howMany ) → Array<ViewNode>internalmodule:engine/view/documentfragment~ViewDocumentFragment#_removeChildrenRemoves number of child nodes starting at the given index and set the parent of these nodes to
null.Parameters
index : numberNumber of the first node to remove.
howMany : numberNumber of nodes to remove.
Defaults to
1
Returns
Array<ViewNode>The array of removed nodes.
_removeCustomProperty( key ) → booleaninternalmodule:engine/view/documentfragment~ViewDocumentFragment#_removeCustomPropertyRemoves the custom property stored under the given key.
Parameters
key : string | symbol
Returns
booleanReturns true if property was removed.
Related:
_setCustomProperty( key, value ) → voidinternalmodule:engine/view/documentfragment~ViewDocumentFragment#_setCustomPropertySets a custom property. They can be used to add special data to elements.
Parameters
key : string | symbolvalue : unknown
Returns
void
Related: