import { nextTick } from 'vue'; import loadingCss from '/@/theme/loading.scss'; // 定义方法 export const NextLoading = { // 载入 css setCss: () => { let link = document.createElement('link'); link.rel = 'stylesheet'; link.href = loadingCss; link.crossOrigin = 'anonymous'; document.getElementsByTagName('head')[0].appendChild(link); }, // 创建 loading start: () => { const bodys: any = document.body; const div = document.createElement('div'); div.setAttribute('class', 'loading-next'); const htmls = `
`; div.innerHTML = htmls; bodys.insertBefore(div, bodys.childNodes[0]); }, // 移除 loading done: () => { nextTick(() => { setTimeout(() => { const el = document.querySelector('.loading-next'); el && el.parentNode?.removeChild(el); }, 1000); }); }, };