时间:2021-05-18
何谓安需装载?
脚本程序一般都是下载后执行,当脚本库非常庞大时,一次性下载起来非常费时,传统的解决方式是,按功能模块把脚本写在不同的文件中,页面上手动加入script标签装载指定内容,但是这有一些缺点,类库的使用者需要知道没个脚本之间的关系,顺序要求等等,而不可能要求每个类库使用者都对其非常熟悉,出错的可能性很大。于是很多框架开始支持导入指令,想使用什么一个导入函数就完了,不必一堆堆的script文件,不用小心翼翼的关注着他们的依赖关系。
安需装载的困境:
早期安需装载(即时同步按需装载)有一个致命的弱点,浏览器阻塞问题。当按需装载某些类库时,通常通过XMLHttpRequest同步装载脚本文件实现,这种情况下,在资源下载完成之前,浏览器将停止响应用户事件、停止页面重画操作。如果网速很慢,这段时间将非常让人讨厌,就像是死机似的。
以前的解决办法是,将常用类库资源直接打包到框架文件中,而按需导入就成了一个宣传的幌子,没有太多实际的价值。
安需装载可分如下三种模式:
l即时同步按需装载(阻塞,JSI、JSVM、dojo)。
最简单的按需装载实现,通过XMLHttpRequest同步装载脚本文件实现。问题是,浏览器使用这种方式同步获取资源时将导致浏览器阻塞:停止响应用户事件、停止页面重画操作。所以,虽然编程最为简单,但是用户体验最差。
2异步按需装载(无阻塞,JSI2.0+)。
异步导入,不必多做解释,用户体验好,但是因为其异步特征,处理起来比较麻烦。
3延迟同步按需装载(无阻塞,JSI2.0+)。
JSI通过动态预装载功能实现的一种同步获取资源的方法,虽然也是同步,但没有阻塞,可以算时兼顾易用性和用户体验的解决方按。缺点时有一定延迟,当前脚本标签中不可用。
使用方法(JSI示例)
以一个代码语法着色程序为例:
类库位置:org/xidea/example/code/code.js
页面位置:example/xxx.html
即时同步按需装载
import("org.xidea.example.code.Code");
varcode1=newCode();
code1.id="libCode";
code1.decorate();
异步按需装载
$import("org.xidea.example.code.Code",function(Code){
varcode1=newCode();
code1.id="libCode";
code1.decorate();
})
延迟同步按需装载(无阻塞,JSI2.0+)。
<script>"../scripts/boot.js"></script>
<script>
$import("org.xidea.example.code.Code",true);
</script>
<script>
varcode1=newCode();
code1.id="pageCode";
code1.decorate();
</script>
测试示例:
地址:
http://jsintegration.sourceforge.net/example/code.html
http:///group/jsier/files
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
ORCLE数据库备份策略1.通过使用exp和imp命令实现数据库导出和导入。有三种模式:a.用户模式:导出(导入)用户所有对象以及对象中的数据;b.表模式:导出
Dreamweaver里有“代码”、“拆分”和“设计”三种工作方式,如下图: Dreamweaver里的三种编辑模式 在“代码”模式的编辑界面,其中,只
互联网赚钱,我认为可以归纳为三种最基本的模式,而从这三种最基本的模式里,派生出不同的互联网收入。这三种基本模式就是商务收入、广告收入和服务收入。 身边经常会有
C#中Excel导入时判断是否被占用三种方法Excel导入时判断是否被占用,三种方法:1:Win7可以,WIN10不可以try{//原理,如果文件可以被移动,说
本文实例讲述了JavaHashMap三种循环遍历方式及其性能对比。分享给大家供大家参考,具体如下:HashMap的三种遍历方式(1)foreachmap.ent