/**
* @description 動(dòng)態(tài)加載js
* @param url js地址
* @returns {Promise} 返回加載狀態(tài)
*/
const loadScript =(url) => {
return new Promise((resolve, reject) => {
// 判斷有沒有加載過 有就不加載了
let scriptList = document.getElementsByTagName('script');
let isLoad = false;
for (let i = 0; i < scriptList.length; i++) {
if (scriptList[i].src === url) {
isLoad = true;
}
}
if (isLoad) {
resolve();
return;
}
// 動(dòng)態(tài)加載js
let script = document.createElement("script");
script.type = "text/javascript";
script.src = url;
document.getElementsByTagName("head")[0].appendChild(script);
script.onload = function () {
resolve();
};
})
}
使用
let isJsZipReady = ref(false)
loadScript(new URL('../utils/jszip.min.js', import.meta.url).href).then(() => {
console.info('jszip ready')
isJsZipReady.value = true
})