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 ...
随机推荐
- Swift使用AVAudioPlayer来调节游戏的背景音乐大小
音乐文件的声音大小有时在做为游戏背景音乐时会过大,而如果我们只是简单应用SKAudioNode来加载音乐的话,是无法进行声音大小的调节的,因此我们必须使用更强大的AVAudioPlayer来进行声音大 ...
- 【springmvc+mybatis项目实战】杰信商贸-3.需求分析与数据库建模
开发步骤需求:生产厂家信息维护基础表FACTORY_C 1.业务需求:a)<需求说明书> 1)描述业务功能 生产厂家模块 功能:为在购销合同模块中的货物信息和附件信 ...
- 凸包算法(Graham扫描法)详解
先说下基础知识,不然不好理解后面的东西 两向量的X乘p1(x1,y1),p2(x2,y2) p1Xp2如果小于零则说明 p1在p2的逆时针方向 如果大于零则说明 p1在p2的顺时针方向 struct ...
- 六:YARN Node Labels
参考:http://dongxicheng.org/mapreduce-nextgen/hadoop-yarn-label-based-scheduling/ 为不同的DATANODE打标签,通过标签 ...
- angularJS遇到的坑
最近在用angularjs做一些东西,由于学艺不精,对angularjs了解不够,导致经常会不小心掉进一些自己挖的坑里(⊙_⊙),在这里记下来,谨防又踩. 1.angularjs ng-show no ...
- popen()与system()
一.popen() 用途:执行shell命令(并读取其输出或向其发送一些输入) 特点:通过管道来与shell命令进行通信 二.system()
- 第十七次ScrumMeeting会议
第十七次Scrum Meeting 时间:2017/12/7 地点:线上+主235 人员:蔡帜 王子铭 游心 解小锐 王辰昱 李金奇 杨森 陈鑫 赵晓宇 照片: 目前工作进展 名字 今日 明天的工作 ...
- Thrift IDL使用方式
I.背景 众所周知,Thrift是一个RPC的框架,其可用于不同语言之间的服务相互调用.比如最近接触到的一个运用环境: *前端使用Node.Js重构了部分我们的老旧代码(前后端未分离的SpringBo ...
- 《JavaScript 高级程序设计》总结
一.JS基本概念 1.命名规则 变量名区分大小写(test和Test是两个不同的变量名),标识符采用驼峰命名格式,即:第一个字母小写,剩下的每个有意义的单词首字母大写: 标识符第一个字符必须是以字母. ...
- 第二次作业 编程题 PAT 1001A+B Format
Github的object-oriented仓库:1001.A+BFormat(20) 1.解题的思路过程 在之前学习C语言时曾经碰到过类似的将数字转换成字符输出的情况,这道题目要求输出的数字每三个间 ...