Element (engine/model)
@ckeditor/ckeditor5-engine/src/model/element
Model element. Type of node that has a name and child nodes.
Important: see Node
to read about restrictions using Element
and Node
API.
Filtering
Properties
-
childCount : Number
readonly
Number of this element's children.
-
Document that owns this node or
null
if the node has no parent or is inside a DocumentFragment. -
endOffset : Number | null
readonly inherited
Offset at which this node ends in it's parent. It is equal to the sum of this node's start offset and offset size. Equals to
null
if the node has no parent. -
index : Number | null
readonly inherited
Index of this node in it's parent or
null
if the node has no parent.Accessing this property throws an error if this node's parent element does not contain it. This means that model tree got broken.
-
isEmpty : Boolean
readonly
Is
true
if there are no nodes inside this element,false
otherwise. -
maxOffset : Number
readonly
Sum of offset sizes of all of this element's children.
-
name : String
readonly
Element name.
-
nextSibling : Node | null
readonly inherited
Node's next sibling or
null
if the node is a last child of it's parent or if the node has no parent. -
offsetSize : Number
readonly inherited
Offset size of this node. Represents how much "offset space" is occupied by the node in it's parent. It is important for position. When node has
offsetSize
greater than1
, position can be placed between that node start and end.offsetSize
greater than1
is for nodes that represents more than one entity, i.e. text node. -
parent : Element | DocumentFragment | null
readonly inherited
Parent of this node. It could be
Element
orDocumentFragment
. Equals tonull
if the node has no parent. -
previousSibling : Node | null
readonly inherited
Node's previous sibling or
null
if the node is a first child of it's parent or if the node has no parent. -
root : Node | DocumentFragment
readonly inherited
The top-most ancestor of the node. If node has no parent it is the root itself. If the node is a part of
DocumentFragment
, it'sroot
is equal to thatDocumentFragment
. -
startOffset : Number | Null
readonly inherited
Offset at which this node starts in it's parent. It is equal to the sum of offsetSize of all it's previous siblings. Equals to
null
if node has no parent.Accessing this property throws an error if this node's parent element does not contain it. This means that model tree got broken.
-
_attrs : Map
private inherited
Attributes set on this node.
-
List of children nodes.
Methods
-
constructor( name, [ attrs ], [ children ] )
protected
Creates a model element.
Note: Constructor of this class shouldn't be used directly in the code. Use the
createElement
method instead.Parameters
name : String
Element's name.
[ attrs ] : Object
Element's attributes. See
toMap
for a list of accepted values.[ children ] : Node | Iterable.<Node>
One or more nodes to be inserted as children of created element.
Overrides: Node#constructor -
getAncestors( options = { [options.includeSelf], [options.parentFirst] } ) → Array
inherited
Returns ancestors array of this node.
Parameters
options : Object
Options object.
Properties[ options.includeSelf ] : Boolean
When set to
true
this node will be also included in parent's array.Defaults to
false
[ options.parentFirst ] : Boolean
When set to
true
, array will be sorted from node's parent to root element, otherwise root element will be the first item in the array.Defaults to
false
Returns
Array
Array with ancestors.
-
getAttribute( key ) → *
inherited
Gets an attribute value for given key or
undefined
if that attribute is not set on node.Parameters
key : String
Key of attribute to look for.
Returns
*
Attribute value or
undefined
.
-
getAttributeKeys() → Iterable.<String>
inherited
Returns iterator that iterates over this node's attribute keys.
Returns
Iterable.<String>
-
getAttributes() → Iterable.<*>
inherited
Returns iterator that iterates over this node's attributes.
Attributes are returned as arrays containing two items. First one is attribute key and second is attribute value. This format is accepted by native
Map
object and also can be passed inNode
constructor.Returns
Iterable.<*>
-
Gets the child at the given index.
-
getChildIndex( node ) → Number
Returns an index of the given child node. Returns
null
if given node is not a child of this element. -
getChildStartOffset( node ) → Number
Returns the starting offset of given child. Starting offset is equal to the sum of offset sizes of all node's siblings that are before it. Returns
null
if given node is not a child of this element. -
getChildren() → Iterable.<Node>
Returns an iterator that iterates over all of this element's children.
Returns
Iterable.<Node>
-
getCommonAncestor( node, options = { [options.includeSelf] } ) → Element | DocumentFragment | null
inherited
Returns a
Element
orDocumentFragment
which is a common ancestor of both nodes.Parameters
node : Node
The second node.
options : Object
Options object.
Properties[ options.includeSelf ] : Boolean
When set to
true
both nodes will be considered "ancestors" too. Which means that if e.g. node A is inside B, then their common ancestor will be B.Defaults to
false
Returns
Element | DocumentFragment | null
-
getNodeByPath( relativePath ) → Node
Returns a descendant node by its path relative to this element.
// <this>a<b>c</b></this> this.getNodeByPath( [ 0 ] ); // -> "a" this.getNodeByPath( [ 1 ] ); // -> <b> this.getNodeByPath( [ 1, 0 ] ); // -> "c"
Parameters
relativePath : Array.<Number>
Path of the node to find, relative to this element.
Returns
-
getPath() → Array.<Number>
inherited
Gets path to the node. The path is an array containing starting offsets of consecutive ancestors of this node, beginning from root, down to this node's starting offset. The path can be used to create Position instance.
const abc = new Text( 'abc' ); const foo = new Text( 'foo' ); const h1 = new Element( 'h1', null, new Text( 'header' ) ); const p = new Element( 'p', null, [ abc, foo ] ); const div = new Element( 'div', null, [ h1, p ] ); foo.getPath(); // Returns [ 1, 3 ]. `foo` is in `p` which is in `div`. `p` starts at offset 1, while `foo` at 3. h1.getPath(); // Returns [ 0 ]. div.getPath(); // Returns [].
Returns
Array.<Number>
The path.
-
hasAttribute( key ) → Boolean
inherited
Checks if the node has an attribute with given key.
Parameters
key : String
Key of attribute to check.
Returns
Boolean
true
if attribute with given key is set on node,false
otherwise.
-
is( type, [ name ] ) → Boolean
Checks whether given model tree object is of given type.
obj.name; // 'listItem' obj instanceof Element; // true obj.is( 'element' ); // true obj.is( 'listItem' ); // true obj.is( 'element', 'listItem' ); // true obj.is( 'text' ); // false obj.is( 'element', 'image' ); // false
Read more in
is
.Parameters
type : String
Type to check when
name
parameter is present. Otherwise, it acts like thename
parameter.[ name ] : String
Element name.
Returns
Boolean
Overrides: Node#is -
isAfter( node ) → Boolean
inherited
Returns whether this node is after given node.
false
is returned if nodes are in different trees (for example, in differentDocumentFragment
s). -
isBefore( node ) → Boolean
inherited
Returns whether this node is before given node.
false
is returned if nodes are in different trees (for example, in differentDocumentFragment
s). -
offsetToIndex( offset ) → Number
Returns index of a node that occupies given offset. If given offset is too low, returns
0
. If given offset is too high, returns index after last child.const textNode = new Text( 'foo' ); const pElement = new Element( 'p' ); const divElement = new Element( [ textNode, pElement ] ); divElement.offsetToIndex( -1 ); // Returns 0, because offset is too low. divElement.offsetToIndex( 0 ); // Returns 0, because offset 0 is taken by `textNode` which is at index 0. divElement.offsetToIndex( 1 ); // Returns 0, because `textNode` has `offsetSize` equal to 3, so it occupies offset 1 too. divElement.offsetToIndex( 2 ); // Returns 0. divElement.offsetToIndex( 3 ); // Returns 1. divElement.offsetToIndex( 4 ); // Returns 2. There are no nodes at offset 4, so last available index is returned.
Parameters
offset : Number
Offset to look for.
Returns
Number
-
toJSON() → Object
Converts
Element
instance to plain object and returns it. Takes care of converting all of this element's children. -
_appendChild( nodes )
protected
-
_clearAttributes()
protected inherited
Removes all attributes from the node.
-
_clone( [ deep ] )
protected
Creates a copy of this element and returns it. Created element has the same name and attributes as the original element. If clone is deep, the original element's children are also cloned. If not, then empty element is removed.
Parameters
[ deep ] : Boolean
If set to
true
clones element and all its children recursively. When set tofalse
, element will be cloned without any child.Defaults to
false
Overrides: Node#_clone -
_insertChild( index, items )
protected
-
_remove()
protected inherited
Removes this node from it's parent.
-
_removeAttribute( key ) → Boolean
protected inherited
Removes an attribute with given key from the node.
Parameters
key : String
Key of attribute to remove.
Returns
Boolean
true
if the attribute was set on the element,false
otherwise.
-
_removeChildren( index, [ howMany ] ) → Array.<Node>
protected
-
_setAttribute( key, value )
protected inherited
Sets attribute on the node. If attribute with the same key already is set, it's value is overwritten.
Parameters
key : String
Key of attribute to set.
value : *
Attribute value.
-
_setAttributesTo( [ attrs ] )
protected inherited
Removes all attributes from the node and sets given attributes.
Parameters
[ attrs ] : Object
Attributes to set. See
toMap
for a list of accepted values.
Static methods
-
Creates an
Element
instance from given plain object (i.e. parsed JSON string). ConvertsElement
children to proper nodes.Parameters
json : Object
Plain object to be converted to
Element
.
Returns
Element
Element
instance created using given plain object.