Create DOM

Every internal DOM node of both the editor interface and the editor content itself must be created through this module.
This is because the interface can be shown in an iframe, or another window.
And in this case, you need to create its elements using the document from this window.
In order not to worry about it yourself, this module was created.

For example, we initialize the editor in iframe mode:

const jodit = Jodit.make('#editor', { iframe: true });

In this case, in plugins, to insert a value, you would have to write the following construction:

const p = jodit.iframe.contentWindow.document.createElement('p');
jodit.s.insertNode(p);

In order not to think about it, the IJodit interface has a field Jodit.createInside and Jodit.create.
Both fields are ICreate instances, but the first should be used for creating elements inside the editor.
And the second is for the editor interface.

The previous example, regardless of the operating mode, will be like this:

const p = jodit.createInside.element('p');
jodit.s.insertNode(p);

This method of creating DOM elements has one more advantage, you can add the option Config.createAttributes
And then, for each created element, the attributes you specified will already be set:

const jodit = Jodit.make('#editor', {
  createAttributes: {
    p: {
      style: 'color: red'
    },
    a: a => {
      a.title = 'Some title';
    }
  }
});

const p = jodit.createInside.element('p');
console.log(p.style.cssText); // color: red

const a = jodit.createInside.element('a');
console.log(a.title); // Some title

To create DOM elements from text, you should also use this module:

const p = jodit.createInside.fromHTML('<p>text</p>');
jodit.s.insertNode(p);

Classes