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 |
throw new Error( '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 |
var ua = navigator.userAgent.toLowerCase(); |
015 |
return ua.indexOf( 'msie' ) >= 0; |
017 |
loadRes : function (modelName,prames,callback){ |
019 |
var Res = document.createElement(prames.tagName); |
020 |
for ( var k in prames){ |
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 |
throw new Error( 'res error:' + modelName+ '.js' ); |
046 |
removeUi : function (modelName){ |
050 |
this .loadedUi[modelName] = false ; |
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); |
064 |
loadUi : function (modelName,callback,setting){ |
068 |
callback = callback || function (){}; |
069 |
if ( this .loadedUi[modelName] == true ){ |
074 |
var deafult_setting = { |
079 |
for ( var key in setting){ |
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 ( var i=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 ...
随机推荐
- selenium,unittest——驾照科目一网上答题自动化
需求很简单,所有题目全选A,然后点提交出分,校验是否到达出分这步 遇到的坑有这几个,一个是assertIn哪个是校验哪个是文本要分清,还有code的编码统一到Unicode,最后就是xpath定位各个 ...
- JVM--内存模型与线程
一.硬件与效率的一致性 计算机的存储设备与处理器的运算速度存在几个数量级的差距,现在计算机系统不得不在内存和处理器之间增加一层高速缓存(cache)来作为缓冲.将运算需要的数据复制到缓存中,让运算能够 ...
- chrome编辑器与截图
在地址栏中输入 data:text/html,<html contenteditable>即可使用编辑功能,打开控制台,ctrl + shift + p 调用命令面板,输入 capture ...
- Python入门(4)
一.while循环 有时候,你可能需要计算机来帮重复做一件事,这时就需要循环. while condition: statements (else: statements ) 当condition条件 ...
- 在 Ubuntu 下安装 Deepin 的 QQ、微信、百度云和迅雷等软件
在以前的文章 Ubuntu 常用软件推荐(QQ.微信.MATLAB等)及安装过程 中,我们用 Wine QQ 和 Electronic Wechat 来解决 Ubuntu 系统下使用 QQ 和微信的难 ...
- hibernate提示Unknown entity: :xxx
错误提示: org.hibernate.MappingException: Unknown entity: org.dao.po.Role at org.hibernate.internal.Sess ...
- 贵州省未来二十年的投资机会的探讨2>
房产投资 升值最快的 在教育资源丰富 生活方便的 地方 价格和地段取其中之一. 其次 车位 再其次墓地等 公寓住房. 还有商标 和网站注册 公司注册 除了以上的这些 还有茅台生效酒 收藏
- DataTable转Json,Json转DataTable
// 页面加载时 /// </summary> /// <param name="sender"></param> /// <param ...
- Error: Could not find or load main class org.apache.hadoop.mapreduce.v2.app.MRAppMaster
自己搭建了一套伪分布的大数据环境,运行Hadoop包中自带的示例时,出现如下错误: 错误: 找不到或无法加载主类 org.apache.hadoop.mapreduce.v2.app.MRAppMas ...
- windows编程了解
文章:浅谈Windows API编程 (这个经典)