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. Linux命令应用大词典-第13章 用户和组群管理

    13.1 useradd:创建用户账户 13.2 adduser:创建用户账户 13.3 lnewusers:创建用户账户 13.4 usermod:修改用户账户 13.5 userdel:删除用户账 ...

  2. 【转】cocos2dx3.2学习笔记之Director(导演类)

    转载:https://blog.csdn.net/u013435551/article/details/38579747 在Cocos2d-x中,把统筹游戏大局的类抽象为导演类(Director),D ...

  3. Spring Cloud(五):Hystrix 监控面板【Finchley 版】

    Spring Cloud(五):Hystrix 监控面板[Finchley 版]  发表于 2018-04-16 |  更新于 2018-05-10 |  在上一篇 Hystrix 的介绍中,我们提到 ...

  4. 373. Partition Array by Odd and Even【LintCode java】

    Description Partition an integers array into odd number first and even number second. Example Given  ...

  5. ArrayList与LinkedList的普通for循环遍历

    对于大部分Java程序员朋友们来说,可能平时使用得最多的List就是ArrayList,对于ArrayList的遍历,一般用如下写法: public static void main(String[] ...

  6. Hybrid APP基础篇(五)->JSBridge实现示例

    说明 JSBridge实现示例 目录 前言 参考来源 楔子 JS实现部分 说明 实现 Android实现部分 说明 JSBridge类 实现 Callback类 实现 Webview容器关键代码 实现 ...

  7. 自测之Lesson5:标准I/O

    题目:使用perror函数和strerror函数编写一个程序. 程序代码: #include <stdio.h> #include <errno.h> #include < ...

  8. 条款02:尽量以const,enum,inline替换#define

    一.概述 尽量少用预处理器——宏替换 二.细节 1. 关于宏替换之常量 旧版本:#define N 10; 新版本:const int n = 10; 比较:#define不被视为语言的一部分,记号名 ...

  9. Python 元组 集合

    1. 元组 >>> a = (1,2,3,4,5) >>> b = list(a) #转换成列表对象, 可以更改 >>> b [1, 2, 3, ...

  10. iOS开发Interface Builder技巧

    1.使view的Size与view中的Content相适应:选中任意的一个view,然后Editor->Size to Fit Content,或者简单的按 ⌘=接着就会按照下面的规则对选中vi ...