1234567891011121314151617181920212223242526272829303132 |
- import { isClient } from '@vueuse/core'
- const globalNodes: HTMLElement[] = []
- let target: HTMLElement = !isClient ? (undefined as any) : document.body
- export function createGlobalNode(id?: string) {
- const el = document.createElement('div')
- if (id !== undefined) {
- el.setAttribute('id', id)
- }
- target.appendChild(el)
- globalNodes.push(el)
- return el
- }
- export function removeGlobalNode(el: HTMLElement) {
- globalNodes.splice(globalNodes.indexOf(el), 1)
- el.remove()
- }
- export function changeGlobalNodesTarget(el: HTMLElement) {
- if (el === target) return
- target = el
- globalNodes.forEach((el) => {
- if (el.contains(target) === false) {
- target.appendChild(el)
- }
- })
- }
|