首頁 > web前端 > js教程 > 主體

原生JS如何動態載入JS和CSS檔案以及程式碼腳本

不言
發布: 2018-07-20 11:25:55
原創
1469 人瀏覽過

這篇文章要跟大家介紹的內容是關於原生JS如何動態載入JS和CSS檔案以及程式碼腳本,有著一定的參考價值,有需要的朋友可以參考一下。

DOM readyState屬性共5中狀態

  1. #uninitialized:初始狀態

  2. #loading:document載入中

  3. #loaded: document載入完成

  1. #interactive
  2. :已載入並可與使用者交互,但還需要載入圖片等其他資源
  3. #complete

    :全部資源載入完成

  4. DOM文件載入順序:
  5. #解析HTML結構
  6. 載入外部腳本和樣式表檔案(loading)

解析並執行腳本

#DOM樹建置完成(readyState:interactive)

載入外部資源檔案(圖片等)

頁面載入完成(readyState:complete)
######動態載入公用方法###
var DynamciLoadUtil = {
    // 动态加载外部js文件,并执行回调
    loadJS: function(url, callback){
        var script = document.createElement('script');
        script.type = 'text/javascript';
        script.src = url;
        if(typeof callback == 'function'){
            script.onload = script.onreadystatechange = function(){
                if(!this.readyState || this.readyState == 'loaded'
                                    || this.readyState == 'complete'){
                    callback();
                    script.onload = script.onreadystatechange = null;
                }
            }
        }
        document.body.appendChild(script);
        //document.getElementsByTagName('body')[0].appendChild(script);
    },
    // 行内方式动态加载js代码
    loadJSText: function(jsText){
        var script = document.createElement('script');
        script.type = 'text/javascript';
        try {
            // Firefox,Safari,Chrome,Opera支持
            script.appendChild(document.createTextNode(jsText));
        } catch(ex){
            // IE早期的浏览器,需要使用script的text属性来指定js代码
            script.text = jsText;
        }
        document.body.appendChild(script);
    },
    // 动态加载外部CSS文件
    loadCSS:function(url){
        var link = document.createElement('link');
        link.rel = 'stylesheet';
        link.type = 'text/css';
        link.url = url;
        document.getElementsByTagName('head')[0].appendChild(link);
    },
    // 使用<style>标签包含嵌入式CSS
    loadCSSText: function(cssText){
        var style = document.createElement('style');
        style.type = 'text/css';
        try{
            // Firefox,Safari,Chrome,Opera支持
            style.appendChild(document.createTextNode(cssText));
        } catch(ex){
            // IE早期浏览器,需要使用style元素的styleSheet属性的cssText属性
            style.styleSheet.cssText = cssText;
        }
    }
}
登入後複製
###相關推薦:############js實作重建二元樹的演算法解析###############JavaScript中Object.defineProperty( )方法的解析###############

以上是原生JS如何動態載入JS和CSS檔案以及程式碼腳本的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!