原生JS動態加載JS、CSS文件及代碼腳本

DOM readyState屬性共5中狀態

  1. uninitialized:初始狀態
  2. loading:document加載中
  3. loaded: document加載完成
  4. interactive:已加載並可與用戶交互,但還須要加載圖片等其餘資源
  5. complete:所有資源加載完成

DOM文檔加載順序:

  1. 解析HTML結構
  2. 加載外部腳本和樣式表文件(loading)
  3. 解析並執行腳本
  4. DOM樹構建完成(readyState:interactive)
  5. 加載外部資源文件(圖片等)
  6. 頁面加載完成(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;
        }
    }
}
相關文章
相關標籤/搜索