linkedom
Version:
A triple-linked lists based DOM implementation
74 lines (60 loc) • 2 kB
JavaScript
;
const {ELEMENT_NODE} = require('./constants.js');
const {END, MIME, NEXT, PREV} = require('./symbols.js');
const $String = String;
exports.String = $String;
const getEnd = node => node.nodeType === ELEMENT_NODE ? node[END] : node;
exports.getEnd = getEnd;
const ignoreCase = ({ownerDocument}) => ownerDocument[MIME].ignoreCase;
exports.ignoreCase = ignoreCase;
const knownAdjacent = (prev, next) => {
prev[NEXT] = next;
next[PREV] = prev;
};
exports.knownAdjacent = knownAdjacent;
const knownBoundaries = (prev, current, next) => {
knownAdjacent(prev, current);
knownAdjacent(getEnd(current), next);
};
exports.knownBoundaries = knownBoundaries;
const knownSegment = (prev, start, end, next) => {
knownAdjacent(prev, start);
knownAdjacent(getEnd(end), next);
};
exports.knownSegment = knownSegment;
const knownSiblings = (prev, current, next) => {
knownAdjacent(prev, current);
knownAdjacent(current, next);
};
exports.knownSiblings = knownSiblings;
const localCase = ({localName, ownerDocument}) => {
return ownerDocument[MIME].ignoreCase ? localName.toUpperCase() : localName;
};
exports.localCase = localCase;
const setAdjacent = (prev, next) => {
if (prev)
prev[NEXT] = next;
if (next)
next[PREV] = prev;
};
exports.setAdjacent = setAdjacent;
/**
* @param {import("../interface/document.js").Document} ownerDocument
* @param {string} html
* @return {import("../interface/document-fragment.js").DocumentFragment}
*/
const htmlToFragment = (ownerDocument, html) => {
const fragment = ownerDocument.createDocumentFragment();
const elem = ownerDocument.createElement('');
elem.innerHTML = html;
const { firstChild, lastChild } = elem;
if (firstChild) {
knownSegment(fragment, firstChild, lastChild, fragment[END]);
let child = firstChild;
do {
child.parentNode = fragment;
} while (child !== lastChild && (child = getEnd(child)[NEXT]));
}
return fragment;
};
exports.htmlToFragment = htmlToFragment;