From d43c58771c9745aaf4d9e4c7282b0cbe870b006c Mon Sep 17 00:00:00 2001 From: Tomas Hubelbauer Date: Sun, 13 Oct 2024 13:44:07 +0200 Subject: [PATCH] Allow `append` to receive multiple elements and implement `prepend` as well This might come in handy. --- index.ts | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/index.ts b/index.ts index 758ac44..592f558 100644 --- a/index.ts +++ b/index.ts @@ -35,11 +35,22 @@ class Element implements Node { // Note that this information is not exposed in the `Element` web interface isVoid: boolean; - append(element: Element) { - this.children.push(element); - element.parentNode = this; - element.parentElement = this; - element.ownerDocument = this.ownerDocument; + prepend(...elements: Element[]) { + this.children.unshift(...elements); + for (const element of elements) { + element.parentNode = this; + element.parentElement = this; + element.ownerDocument = this.ownerDocument; + } + } + + append(...elements: Element[]) { + this.children.push(...elements); + for (const element of elements) { + element.parentNode = this; + element.parentElement = this; + element.ownerDocument = this.ownerDocument; + } } get outerHTML() {