happy-dom
Version:
Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.
50 lines • 1.67 kB
JavaScript
import DocumentType from '../nodes/document-type/DocumentType.js';
import * as PropertySymbol from '../PropertySymbol.js';
import NodeFactory from '../nodes/NodeFactory.js';
/**
* The DOMImplementation interface represents an object providing methods which are not dependent on any particular document. Such an object is returned by the.
*/
export default class DOMImplementation {
#document;
/**
* Constructor.
*
* @param document Document.
*/
constructor(document) {
this.#document = document;
}
/**
* Creates and returns an XML Document.
*
* TODO: Not fully implemented.
*
* @param _namespaceURI Namespace URI.
* @param _qualifiedName Qualified name.
* @param [_docType] Document type.
*/
createDocument(_namespaceURI, _qualifiedName, _docType) {
return new this.#document[PropertySymbol.window].HTMLDocument();
}
/**
* Creates and returns an HTML Document.
*/
createHTMLDocument() {
return new this.#document[PropertySymbol.window].HTMLDocument();
}
/**
* Creates and returns an HTML Document.
*
* @param qualifiedName Qualified name.
* @param publicId Public ID.
* @param systemId System ID.
*/
createDocumentType(qualifiedName, publicId, systemId) {
const documentType = NodeFactory.createNode(this.#document, DocumentType);
documentType[PropertySymbol.name] = qualifiedName;
documentType[PropertySymbol.publicId] = publicId;
documentType[PropertySymbol.systemId] = systemId;
return documentType;
}
}
//# sourceMappingURL=DOMImplementation.js.map