JavaScript无非就是script标签引入页面,但当项目越来越大的时候,单页面引入N个js显然不行,合并为单个文件减少了请求数,但请求的文件体积却很大。这时候最好的做法就是按需引入,动态引入组件js和样式,文件load完成后调用callback,运行js。代码还是很简便的。
1. 判断文件load完成。加载状态ie为onreadystatechange,其他为onload、onerror
| 02 |     Res.onreadystatechange = function(){ | 
 
| 03 |         if(Res.readyState == 'complete'|| Res.readyState == 'loaded'){ | 
 
| 04 |             Res.onreadystatechange = null; | 
 
| 06 |             _self.loadedUi[modelName] = true; | 
 
| 11 |     Res.onload = function(){ | 
 
| 14 |         _self.loadedUi[modelName] = true; | 
 
| 16 |     Res.onerror = function(){ | 
 
| 17 |         thrownewError('res error:'+ modelName+'.js'); | 
 
 
 
2. 所有组件的命名最好保持一致,callback调用也比较方便。还可以根据需要增加参数比如: requires,依赖于那些文件;style,true || false,是否加载样式,等等。
3. 移除操作也可以有,移除script、style标签、delete组件
| 001 | (function(window,undefined){ | 
 
| 008 |             version : window.config.version, | 
 
| 009 |             cssPath : window.config.resServer + '/css/v3/ui', | 
 
| 010 |             jsPath  : window.config.resServer + '/js/v2/ui' | 
 
| 013 |         readyStateChange : function(){ | 
 
| 014 |             varua = navigator.userAgent.toLowerCase(); | 
 
| 015 |             returnua.indexOf('msie') >= 0; | 
 
| 017 |         loadRes : function(modelName,prames,callback){ | 
 
| 019 |             varRes = document.createElement(prames.tagName); | 
 
| 020 |             for(vark inprames){ | 
 
| 022 |                     Res.setAttribute(k,prames[k],0); | 
 
| 025 |             document.getElementsByTagName('head')[0].appendChild(Res); | 
 
| 027 |             if(this.readyStateChange()){ | 
 
| 028 |                 Res.onreadystatechange = function(){ | 
 
| 029 |                     if(Res.readyState == 'complete'|| Res.readyState =='loaded'){ | 
 
| 030 |                         Res.onreadystatechange = null; | 
 
| 032 |                         _self.loadedUi[modelName] = true; | 
 
| 036 |                 Res.onload = function(){ | 
 
| 039 |                     _self.loadedUi[modelName] = true; | 
 
| 041 |                 Res.onerror = function(){ | 
 
| 042 |                     thrownewError('res error:'+ modelName+'.js'); | 
 
| 046 |         removeUi : function(modelName){ | 
 
| 050 |             this.loadedUi[modelName] = false; | 
 
| 052 |             varhead       = document.getElementsByTagName('head')[0]; | 
 
| 053 |             varmodel_js   = document.getElementById('J_model_'+modelName + '_js'); | 
 
| 054 |             varmodel_css  = document.getElementById('J_model_'+modelName + '_css'); | 
 
| 055 |             if(model_js && model_css){ | 
 
| 056 |                 deletewindow.ui[modelName]; | 
 
| 057 |                 head.removeChild(model_js); | 
 
| 058 |                 head.removeChild(model_css); | 
 
| 064 |         loadUi : function(modelName,callback,setting){ | 
 
| 068 |             callback = callback || function(){}; | 
 
| 069 |             if(this.loadedUi[modelName] == true){ | 
 
| 074 |             vardeafult_setting = { | 
 
| 079 |             for(varkey insetting){ | 
 
| 080 |                 deafult_setting[key] = setting[key]; | 
 
| 082 |             deafult_setting['style'] === true&& this.loadRes(modelName,{ | 
 
| 083 |                 id      : 'J_model_'+modelName + '_css', | 
 
| 088 |                 href    : this.config.cssPath + '/'+ modelName + '.css?v='+ this.config.version | 
 
| 091 |             deafult_setting['js'] === true&& this.loadRes(modelName,{ | 
 
| 092 |                 id      : 'J_model_'+modelName + '_js', | 
 
| 095 |                 type    : 'text/javascript', | 
 
| 096 |                 src     : this.config.jsPath + '/'+ modelName + '.js?v='+ this.config.version | 
 
| 098 |             if(deafult_setting.requires.length > 0){ | 
 
| 099 |                 for(vari=0,len = deafult_setting.requires.length;i < len;i++){ | 
 
| 100 |                     this.loadUi(deafult_setting.requires[i]); | 
 
 
 
使用方法:
| 01 | // load comment for feed | 
 
| 02 | window.bus.loadUi('new_comment_feed', function(){ | 
 
| 03 |     window.ui.new_comment_feed($("#J_newsList")); | 
 
| 06 |     requires:['emoticon','addFriend'] | 
 
| 10 | window.bus.loadUi('yy', function(){ | 
 
| 11 |     window.ui.yy(options); | 
 
| 18 | window.bus.loadUi('photoLightbox', function(){ | 
 
| 19 |     window.ui.photoLightbox(options.urlAjaxGetFriendPhoto, options.urlCommentOtherPhoto,$("#J_newsList"),options.myUid,options.myName); | 
 
 
 												
												
						- 详谈LABJS按需动态加载js文件
		为了提高页面的打开和加载速度,我们经常把JS文件放在页面的尾部,但是有些JS必须放在页面前面,这样就会增加页面的加载时间:于是出现了按需动态加载的概念,这个概念就是当页面需要用到这个JS文件或者CSS ... 
- 按需动态加载js
		有些时间我们希望能按需动态加载js文件,而不是直接在HTML中写script标签. 以下为示例代码: var js = document.createElement('script'); js.asy ... 
- 动态加载JS文件,并根据JS文件的加载状态来执行自己的回调函数
		动态加载JS文件,并根据JS文件的加载状态来执行自己的回调函数, 在很多场景下,我们需要在动态加载JS文件的时候,根据加载的状态来进行后续的操作,需要在JS加载成功后,执行另一方法,这个方法是依托在加 ... 
- ExtJS4.x动态加载js文件
		动态加载js文件是ext4.x的一个新特性,可以有效的减少浏览器的压力,提高渲染速度.如动态加载自定义组件 1.在js/extjs/ux目录下,建立自定义组件的js文件. 2.编写MyWindow.j ... 
- Ext JS学习第十天 Ext基础之动态加载JS文件(补充)
		此文用来记录学习笔记: •Ext4.x版本提供的一大亮点就是Ext.Loader这个类的动态加载机制!只要遵循路径规范,即可动态加载js文件,方便把自己扩展组件动态加载进来,并且减轻浏览器的压力. • ... 
- javascript动态加载js文件主流浏览器兼容版
		一.代码示例: <html> <head> <meta http-equiv="Content-Type" content="text/ht ... 
- JavaScript动态加载js文件
		/********************************************************************* * JavaScript动态加载js文件 * 说明: *  ... 
- 动态加载js文件是异步的
		动态加载js文件是异步的. 今天调试一个错误,一个js方法各种调不到. 原因是因为所调方法的js文件是动态加载进来的. <script type="text/javascript&qu ... 
- 动态加载js文件
		由于最近在弄echarts,关于地图类的效果,但是全国地图整体的js文件太大了,加载很耗费资源,所以要根据不同省份加载不同地区的js地图, 于是就想的比较简单, var script = docume ... 
随机推荐
	
									- word record 01
			词义默认包括发音 coil /kɔɪl/ 发音(kuo you) collage /kə'lɑʒ/ 发音(ke la shi) colleague /'kɑliɡ/ 发音 (ka li ge) com ... 
- 了解Python控制流语句——break 语句
			这篇文章主要介绍了详解Python中break语句的用法,是Python入门的呼出知识,需要的朋友可以参考下,python基础系列教程之-Python break语句 跳出循环 break 语句用以中 ... 
- lintcode735. Replace With Greatest From Right
			Given an array of integers, replace every element with the next greatest element (greatest element o ... 
- 孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9并使用pydocx模块将结果写入word文档
			孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9 (完整学习过程屏幕记录视频地址在文末) 今天在上一天的基础上继续完成对我的第一个代码程序的书写. 到今天终于完成了对docx模块针对 ... 
- 从零开始的Python学习Episode 2——运算符与while循环
			一.算术运算符 加法:+,减法:-,乘法*,除法/,整除(地板除)//,取余%,乘方**.  二.逻辑运算符 且:and,或:or,非:not 优先级:not>and>or 短路原则: 对 ... 
- C语言struct中的长度可变数组(Flexible array member)
			C_struct中的长度可变数组(Flexible array member) Flexible array member is a feature introduced in the C99 sta ... 
- $http.get(...).success is not a function 错误解决
			$http.get(...).success is not a function 错误解决 1.6 新版本的AngularJs中用then和catch 代替了success和error,用PRomis ... 
- jQuery File Upload文件上传插件简单使用
			前言 开发过程中有时候需要用户在前段上传图片信息,我们通常可以使用form标签设置enctype=”multipart/form-data” 属性上传图片,当我们点击submit按钮的时候,图片信息就 ... 
- Mysql 工作原理
			刚开始接触一个新的事物的时候,我觉得很有必要从其工作原理入手,弄清楚这个东西的来龙去脉,为接下来的继续深入学习做好铺垫,掌握好其原理有助于我们从整体上来把握这个东西,并且帮助我们在排错过程中理清思路. ... 
- QT分析之调试跟踪系统
			原文地址:http://blog.163.com/net_worm/blog/static/127702419201002004518944/ 在我们前面的分析中,经常看到qWarning()和qDe ...