亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript怎么動態加載js文件

發布時間:2021-06-21 16:07:22 來源:億速云 閱讀:155 作者:chen 欄目:編程語言

這篇文章主要介紹“javascript怎么動態加載js文件”,在日常操作中,相信很多人在javascript怎么動態加載js文件問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”javascript怎么動態加載js文件”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1、動態的插入script標簽來加載腳本。

  function loadScript(url, callback) {
    const script = document.createElement('script');
    script.type = 'text/javascript';
    // 處理IE
    if (script.readyState) {
      script.onreadystatechange = function () {
        if (script.readyState === 'loaded' || script.readyState === 'complete') {
          script.onreadystatechange = null;
          callback();
        }
      }
    } else {
      // 處理其他瀏覽器的情況
      script.onload = function () {
        callback();
      }
    }
    script.src = url;
    document.body.append(script);
  }
 
  // 動態加載js
  loadScript('file.js', function () {
    console.log('加載完成');
  })

2、通過xhr方式加載js文件,不過通過這種方式的話,就可能會面臨著跨域的問題。

  const xhr = new XMLHttpRequest();
  xhr.open('get', 'file.js');
  xhr.onreadystatechange = function () {
    if (xhr.readyState === 4) {
      if (xhr.status >= 200 && xhr.status < 300 || xhr.status === 304) {
        const script = document.createElement('script');
        script.type = 'text/javascript';
        script.text = xhr.responseText;
        document.body.append(script);
      }
    }
  }

3、將多個js文件合并為同一個并壓縮。目前,大多數瀏覽器已經支持并行下載js文件,但并行下載仍有一定數量的限制(基于瀏覽器,一些瀏覽器只能下載4個)。此外,每個js文件都需要建立一個額外的http連接,并且4個25KB的文件比100KB的文件大。因此,最好將多個js文件合并為同一個并壓縮代碼。

到此,關于“javascript怎么動態加載js文件”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

古浪县| 南部县| 卫辉市| 榕江县| 新晃| 马公市| 亚东县| 双柏县| 芒康县| 东乡族自治县| 渭源县| 兴文县| 正镶白旗| 巨野县| 沁水县| 营山县| 化隆| 屯昌县| 威信县| 南京市| 海南省| 内丘县| 娄烦县| 太湖县| 宜宾市| 剑川县| 太白县| 葵青区| 吴旗县| 广州市| 五指山市| 府谷县| 揭西县| 始兴县| 即墨市| 胶州市| 湖州市| 沁源县| 惠来县| 灯塔市| 锡林郭勒盟|