zoukankan      html  css  js  c++  java
  • 高性能JS载入脚本并执行

    1. 一般现代浏览器通过侦听事件获得脚本加载完成时的状态

      var script = document.createElement('script');
      script.type 
      = 'text/javascript';
      //Firefox, Chrome
      script.onload = function(){
        alert(
      'script loaded!');
      };
      script.src 
      = 'http://code.jquery.com/jquery-1.4.2.min.js';
      document.getElementsByTagName(
      'head')[0].appendChild(script);
    2. ie支持另外一种方式,会触发readystatechange事件

      loading:开始下载

      complete:所有数据已准备就绪

      var script = document.createElement('script');
      script.type 
      = 'text/javascript';
      //IE
      script.onreadystatechange = function(){
          
      if(script.readyState == 'loaded' || script.readyState == 'complete'){
              script.onreadystatechange 
      = null;
              alert(
      'Script loaded');
          }
      }
      script.src 
      = 'http://code.jquery.com/jquery-1.4.2.min.js';
      document.getElementsByTagName(
      'head')[0].appendChild(script);

    3. 兼容方法

      /**
      * 载入脚本
      * @param {String} url 载入的地址
      * @param {Function} callback 载入后需执行的函数
      */
      function loadScript(url, callback){
        
      var 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 { //非IE
            script.onload = function(){
                callback();
            }
        }
        script.src 
      = null;
        document.getElementsByTagName(
      'head')[0].appendChild(script);
      }
      //example
      loadScript('http://code.jquery.com/jquery-1.4.2.min.js'function(){
        alert(
      'File is loaded!');
      })

    4. XMLRequest脚本注入

      var xhr = new XMLHttpRequest();
      xhr.open(
      'get''http://code.jquery.com/jquery-1.4.2.min.js'true);
      xhr.onreadystatechange 
      = function(){
          
      if(xhr.readySate == 4){
              
      if(xhr.status >= 200 && shr.status < 300 || xhr.status == 304){ //200 有效响应; 304 从缓存读取
                  var script = document.createElement('script');
                  script.type 
      = 'text/javascript';
                  script.text 
      = xhr.responseText;
                  document.body.appendChild(script);
              }
          }
      };
      xhr.send(
      null);
  • 相关阅读:
    C#托盘图标
    线程相关整理
    Quartz.NET 快速入门
    (转)IE内存泄露,iframe内存泄露造成的原因和解决方案
    美化console.log的文本(转载)
    mongoDB学习资料整理
    EF7学习资料整理
    Oracle常用
    Node.js学习资料整理
    【大型网站技术实践】初级篇:借助Nginx搭建反向代理服务器(转)
  • 原文地址:https://www.cnblogs.com/jikey/p/2084578.html
Copyright © 2011-2022 走看看