JavaScript无非就是script标签引入页面,但当项目越来越大的时候,单页面引入N个js显然不行,合并为单个文件减少了请求数,但请求的文件体积却很大。这时候最好的做法就是按需引入,动态引入组件js和样式,文件load完成后调用callback,运行js。代码还是很简便的。

1. 判断文件load完成。加载状态ie为onreadystatechange,其他为onload、onerror

01 if(isie){
02     Res.onreadystatechange = function(){
03         if(Res.readyState == 'complete' || Res.readyState == 'loaded'){
04             Res.onreadystatechange = null;
05             callback();
06             _self.loadedUi[modelName] = true;
07         }
08     }
09 }
10 else{
11     Res.onload = function(){
12         Res.onload = null;
13         callback();
14         _self.loadedUi[modelName] = true;
15     }
16     Res.onerror = function(){
17         throw new Error('res error:' + modelName+'.js');
18     }
19 }

2. 所有组件的命名最好保持一致,callback调用也比较方便。还可以根据需要增加参数比如: requires,依赖于那些文件;style,true || false,是否加载样式,等等。

3. 移除操作也可以有,移除script、style标签、delete组件

001 (function(window,undefined){
002     if(!window.ui) {
003         window.ui  = {};
004     }
005     //动态加载ui的js
006     window.bus  = {
007         config : {
008             version : window.config.version,
009             cssPath : window.config.resServer + '/css/v3/ui',
010             jsPath  : window.config.resServer + '/js/v2/ui'
011         },
012         loadedUi : {},
013         readyStateChange : function(){
014             var ua = navigator.userAgent.toLowerCase();
015             return ua.indexOf('msie') >= 0;
016         },
017         loadRes : function(modelName,prames,callback){
018             var _self = this;
019             var Res = document.createElement(prames.tagName);
020             for(var in prames){
021                 if(k != 'tagName'){
022                     Res.setAttribute(k,prames[k],0);
023                 }
024             }
025             document.getElementsByTagName('head')[0].appendChild(Res);
026  
027             if(this.readyStateChange()){
028                 Res.onreadystatechange = function(){
029                     if(Res.readyState == 'complete' || Res.readyState =='loaded'){
030                         Res.onreadystatechange = null;
031                         callback();
032                         _self.loadedUi[modelName] = true;
033                     }
034                 }
035             }else{
036                 Res.onload = function(){
037                     Res.onload = null;
038                     callback();
039                     _self.loadedUi[modelName] = true;
040                 }
041                 Res.onerror = function(){
042                     throw new Error('res error:' + modelName+'.js');
043                 }
044             }
045         },
046         removeUi : function(modelName){
047             if(!modelName){
048                 return true
049             };
050             this.loadedUi[modelName] = false;
051  
052             var head       = document.getElementsByTagName('head')[0];
053             var model_js   = document.getElementById('J_model_'+modelName + '_js');
054             var model_css  = document.getElementById('J_model_'+modelName + '_css');
055             if(model_js && model_css){
056                 delete window.ui[modelName];
057                 head.removeChild(model_js);
058                 head.removeChild(model_css);
059                 return true;
060             }else{
061                 return false;
062             }
063         },
064         loadUi : function(modelName,callback,setting){
065             if(!modelName){
066                 return true
067             };
068             callback = callback || function(){};
069             if(this.loadedUi[modelName] == true){
070                 callback();
071                 return true
072             }
073  
074             var deafult_setting = {
075                 style : true,
076                 js    : true,
077                 requires : []
078             }
079             for(var key in setting){
080                 deafult_setting[key] = setting[key];
081             }
082             deafult_setting['style'] === true && this.loadRes(modelName,{
083                 id      : 'J_model_'+modelName + '_css',
084                 name    : modelName,
085                 tagName : 'link',
086                 type    : 'text/css',
087                 rel     : 'stylesheet',
088                 href    : this.config.cssPath + '/' + modelName + '.css?v=' this.config.version
089             });
090  
091             deafult_setting['js'] === true && this.loadRes(modelName,{
092                 id      : 'J_model_'+modelName + '_js',
093                 name    : modelName,
094                 tagName : 'script',
095                 type    : 'text/javascript',
096                 src     : this.config.jsPath + '/' + modelName + '.js?v='this.config.version
097             },callback);
098             if(deafult_setting.requires.length > 0){
099                 for(var i=0,len = deafult_setting.requires.length;i < len;i++){
100                     this.loadUi(deafult_setting.requires[i]);
101                 }
102             }
103         }
104     }
105 })(window)

使用方法:

01 // load comment for feed
02 window.bus.loadUi('new_comment_feed'function(){
03     window.ui.new_comment_feed($("#J_newsList"));
04 },{
05     style : false,
06     requires:['emoticon','addFriend']
07 });
08  
09 // load new yy ui
10 window.bus.loadUi('yy'function(){
11     window.ui.yy(options);
12 },{
13     style:false,
14     requires:['emoticon']
15 });
16  
17 // load photoLightbox
18 window.bus.loadUi('photoLightbox'function(){
19     window.ui.photoLightbox(options.urlAjaxGetFriendPhoto, options.urlCommentOtherPhoto,$("#J_newsList"),options.myUid,options.myName);
20 });

如何按需动态加载js文件的更多相关文章

  1. 详谈LABJS按需动态加载js文件

    为了提高页面的打开和加载速度,我们经常把JS文件放在页面的尾部,但是有些JS必须放在页面前面,这样就会增加页面的加载时间:于是出现了按需动态加载的概念,这个概念就是当页面需要用到这个JS文件或者CSS ...

  2. 按需动态加载js

    有些时间我们希望能按需动态加载js文件,而不是直接在HTML中写script标签. 以下为示例代码: var js = document.createElement('script'); js.asy ...

  3. 动态加载JS文件,并根据JS文件的加载状态来执行自己的回调函数

    动态加载JS文件,并根据JS文件的加载状态来执行自己的回调函数, 在很多场景下,我们需要在动态加载JS文件的时候,根据加载的状态来进行后续的操作,需要在JS加载成功后,执行另一方法,这个方法是依托在加 ...

  4. ExtJS4.x动态加载js文件

    动态加载js文件是ext4.x的一个新特性,可以有效的减少浏览器的压力,提高渲染速度.如动态加载自定义组件 1.在js/extjs/ux目录下,建立自定义组件的js文件. 2.编写MyWindow.j ...

  5. Ext JS学习第十天 Ext基础之动态加载JS文件(补充)

    此文用来记录学习笔记: •Ext4.x版本提供的一大亮点就是Ext.Loader这个类的动态加载机制!只要遵循路径规范,即可动态加载js文件,方便把自己扩展组件动态加载进来,并且减轻浏览器的压力. • ...

  6. javascript动态加载js文件主流浏览器兼容版

    一.代码示例: <html> <head> <meta http-equiv="Content-Type" content="text/ht ...

  7. JavaScript动态加载js文件

    /********************************************************************* * JavaScript动态加载js文件 * 说明: * ...

  8. 动态加载js文件是异步的

    动态加载js文件是异步的. 今天调试一个错误,一个js方法各种调不到. 原因是因为所调方法的js文件是动态加载进来的. <script type="text/javascript&qu ...

  9. 动态加载js文件

    由于最近在弄echarts,关于地图类的效果,但是全国地图整体的js文件太大了,加载很耗费资源,所以要根据不同省份加载不同地区的js地图, 于是就想的比较简单, var script = docume ...

随机推荐

  1. 新的征程 in ZJU

    争取考上了心仪的学校 并进入了心仪的实验室 但是对我来说,未来将是更多的挑战 首先我觉得我学习能力还是不足,无法做到一天的高效率学习 实验室的方向是可视化,我觉得这个是个非常复杂的方向 数学,pyth ...

  2. Python|一文简单看懂 深度&广度 优先算法

    一.前言 以后尽量每天更新一篇,也是自己的一个学习打卡!加油!今天给大家分享的是,Python里深度/广度优先算法介绍及实现. 二.深度.广度优先算法简介 1. 深度优先搜索(DepthFirstSe ...

  3. [CodeForce721C]Journey

    题目描述 Recently Irina arrived to one of the most famous cities of Berland - the Berlatov city. There a ...

  4. Android开发-API指南-<receiver>

    <receiver> 英文原文:http://developer.android.com/guide/topics/manifest/receiver-element.html 采集(更新 ...

  5. 国内版Office365实现MFA的方案(未完)

    现在二十一世纪互联版也可以实现了MFA,现在也就是2017年3月份,支持了PC,但是对移动端应用还是不支持的,请了解. 具体方法如下: 登录国内版Office365(事例为高级商业版 https:// ...

  6. 今日头条 2018 AI Camp 5 月 26 日在线笔试编程题第二道——最小分割分数

    题目: 给 n 个正整数 a_1,…,a_n, 将 n 个数顺序排成一列后分割成 m 段,每一段的分数被记为这段内所有数的和,该次分割的分数被记为 m 段分数的最大值.问所有分割方案中分割分数的最小值 ...

  7. java一些面试题

    java虚拟机 什么时候会触发full gc System.gc()方法的调用 老年代空间不足 永生区空间不足(JVM规范中运行时数据区域中的方法区,在HotSpot虚拟机中又被习惯称为永生代或者永生 ...

  8. hadoop问题集(1)

        参考: http://dataunion.org/22887.html 1.mapreduce_shuffle does not exist 执行任何时报错: Container launch ...

  9. Python3 循环表达式

    一 While循环 基本循环 while 条件: 执行内容 #循环体 ... #循环体 ... #循环体 # 若条件为真,执行循环体内容 # 若条件为假,不执行循环体内容 实例1(Python 3.0 ...

  10. android入门 — ListView

    ListView主要是用来解决大量数据展示的问题,它的用途很广泛,几乎所有的app都会用到,比如说知乎.今日头条.微博.通讯录等. ListView允许用户通过上下滑动的方式将屏幕外的数据滚动到屏幕中 ...