亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何等待附加到正文的 <script> 完成執行

如何等待附加到正文的 <script> 完成執行

largeQ 2024-01-11 16:33:31
當用戶單擊按鈕時,我需要將外部腳本附加到我的正文中。這是要求。菜鳥問題。假設外部庫創建了一個 window.newLib 變量。當 newLib 變量可供我使用時,如何通知我?我嘗試了這個,但 onload 沒有被調用:  const script = document.createElement('script');  script.innerHTML = 'window.test = 1; console.log("test defined.");';  script.onload = "console.log('onload called.', window.test)"  script.async = false;  document.body.appendChild(script);這可行,但對我來說似乎很臟。有沒有更好的辦法?const injectScript = () => {  const script = document.createElement('script');  script.innerHTML = 'setTimeout(() => {window.test = 1},10500); console.log("test defined.");';  script.async = false;  document.body.appendChild(script);}const nap = ms => new Promise(res => setTimeout(res, ms));const maxAttempts = 100;const msNap = 100; // 10s timeoutconst start = async () => {  injectScript();  let id = 0;  while (true) {    if (++id === maxAttempts) {      throw(`Lib took too long to load: ${id * msNap}ms`);    }    if (window.test) break;    await nap(msNap);  }  console.log('External lib correctly loaded.');};start();
查看完整描述

2 回答

?
吃雞游戲

TA貢獻1829條經驗 獲得超7個贊

這似乎按預期工作:


const script = document.createElement('script');

script.src = 'data:text/html,id = 0;while(true){ if(++id==1000000) break;} window.test = 1; console.log("test defined.");';

script.onload = () => console.log('onload called.', window.test);

document.body.appendChild(script);


查看完整回答
反對 回復 2024-01-11
?
慕村225694

TA貢獻1880條經驗 獲得超4個贊

嘗試這個:


const injectScript = () => {

        const script = document.createElement('script');

        script.innerHTML = 'console.log("Function loaded..."); window.postMessage({cmd:"loaded"});';

        script.async = false;

        document.body.appendChild(script);

        }


        setTimeout(injectScript, 3000);


        window.addEventListener('message', function(e){

            if(e.data.cmd === 'loaded'){

                console.log('external library loaded');

            }

        });


查看完整回答
反對 回復 2024-01-11
  • 2 回答
  • 0 關注
  • 194 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號