用headjs来管理和加载js 提高网站加载速度


Posted in Javascript onNovember 29, 2016

现在有许多成熟的js模块加载器,比如requirejs和seajs等,但是对一些小的项目来说,它们的功能可能太过于“强大”,也许我们只是想要有一个能动态加载js的功能,或许我们只是想装B一下,让自己写出的页面没有一大堆的<script src=”a.js”></script>这样的东西。前面说的两种js加载器都是更强调模块性,也就是更强调js文件的组织和管理,更适用于大的项目。

就像刚刚说的,我只想有一个js文件加载器,我只需提供给它一个js文件的地址就行了的那种呢?那就进入我们的主题了,使用headjs吧。headjs其实是一整套的工具,但我只想介绍的是它其中的Javascript Loader功能。以下是它的基本用法:

head.js("/path/to/file.js");

最简单的用法,提供一个js的文件的地址给它作为参数,然后它就会默默的在背后进行无阻塞的加载了,至于什么时候加载完可用了,谁也不知道。

head.js("/path/to/file.js", function() {
 /*js加载完成*/
});

最基本的用法,除了提供一个地址参数外,还提供一个回调函数作为第二个参数。在js加载完成后,回调用回调函数,你可以把依赖该js的代码写在回调函数里。

head.js("file1.js", "file2.js", ... "fileN.js");

提供多个js文件地址,这些js会并行的加载,但会按照参数给定的先后顺序执行这些文件,例如即使file2.js比file1.js先加载完成,但它还会一直等到在file1.js加载和执行完后再执行。

head.js("file1.js", "file2.js", function() {
 
});

并行加载多个js,并按参数顺序执行,所有js准备完成时,执行回调函数。

head.js("file1.js");
head.js("file2.js");
head.js("file3.js");

多个js并行加载,并且谁先加载完就先执行谁

head.js("file1.js").js("file1.js").js("file3.js");

上一种方法的链式调用法

这样的话用headjs来加载js文件基本都够用了,而且还能处理依赖关系。当是如果你继续装B,弄一个网站,巴不得什么特效都用上,这里找一个jquery插件,那里再找一个,总之就是弄非常多的文件,其中又有复杂的依赖关系,那该肿么办?这还用问吗,以上的那几个用法完全能解决。但转念一想,既然装B那就一装到底吧,现在不是流行模块什么的吧,那咱也整个模块吧,但不是像commonJS说的那么复杂,就是定义一个模块,然后规定这个模块是有那几个js文件组成的,其中的依赖关系又如何等等。那就动手吧,headjs使用的是MTI协议,修改下它应该也是没问题的吧。?潘坑肿案吒凰Я耍?涫邓凳切薷模?共蝗缢凳窃黾蛹付未?虢?ィ??壹釉匾览档裙δ芡耆?怯?eadjs的api实现的。

这里,我给headjs的新增了两个方法,一个是add(name,file,preload)添加模块,参数name是模块名称,file是要用到的js文件地址,如果有多个文件,并且存在依赖关系,则file可以是一个数组,这个数组的里元素就是用到的文件地址,并且按数组元素的顺序进行依赖。第三个参数preload用指定是否预加载模块文件,如果为false,则在使用该模块的时候才会加载文件,为true时则在定义模块时就会立即加载所用到的文件,默认为false

另一个是use(name,callback),这个方法用来使用模块。name是用add()方法定义的模块名,callback是该模块已经加载完成后调用的回调函数。

于是我们就可以这样来使用headjs了:

head.add('jqueryui',[jquery.js,jqueryui.js]);//定义模块
head.use('jqueryui',function(){
 //可以使用jqueryui啦 
});

如果模块很多,则模块的定义代码可以单独写在一个文件里,并且引入了headjs的后,就立即加载该模块定义文件。这个过程可以很简单的像这样来实现:

<script src="head.js" init="init"></script>

看到那个init属性没有,我把它叫做初始化属性,init的值表示文件名,例如上面init就代表与headjs同目录的init.js这个文件。所谓的初始化就是在使用use()之前,init文件一定是已经加载好了的。所以可以把模块的定义写在初始化文件中。

<script src="head.js" init="init" main="main"></script>

尼玛,这是要闹哪样啊,怎么又多了个main属性,好吧,我承认是看到别人有这个东西于是手贱也跟风弄了一个。这个main属性代表的是模块名,就是head.js与init.js文件都加载完成后,就会自动执行main属性指定的模块(当然要先在init中定义该模块)。所以有了这两个东东后,我们就可以在页面没有一句js代码的情况下(除了引入headjs那段标签),执行很复杂的代码了。

还有一个要说明的地方,就是模块文件的存放位置。模块文件应该和head.js存放在同一个目录,比如head.add(‘a','a.js'),这里的a.js的路径是和head.js相同的,就是说模块文件的路径是相对于head.js存放的路径的,而且只可以往下走,不可以往上走,比如:

head.add(‘a','a/a.js')//正确

head.add(‘a','../a.js')//错误,不能往上定位

最后,放上修改过后的head.js源文件,不是压缩版,里面改的地方都有注释。

以上就是本文的全部内容,希望对大家有所帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
js 对联广告、漂浮广告封装类(IE,FF,Opera,Safari,Chrome
Nov 26 Javascript
jQuery实现TAB风格的全国省份城市滑动切换效果代码
Aug 24 Javascript
JS实现的简洁二级导航菜单雏形效果
Oct 13 Javascript
浅析jquery与checkbox的checked属性的问题
Apr 27 Javascript
基于HTML+CSS+JS实现增加删除修改tab导航特效代码
Aug 05 Javascript
jQuery tagsinput在h5邮件客户端中应用详解
Sep 26 Javascript
详解vue 中使用 AJAX获取数据的方法
Jan 18 Javascript
jQuery代码实现实时获取时间
Jan 29 Javascript
angular6.x中ngTemplateOutlet指令的使用示例
Aug 09 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
Aug 09 Javascript
javascript实现雪花飘落效果
Aug 19 Javascript
原生小程序封装跑马灯效果
Oct 21 Javascript
巧用数组制作图片切换js代码
Nov 29 #Javascript
JS插件plupload.js实现多图上传并显示进度条
Nov 29 #Javascript
文件上传插件SWFUpload的使用指南
Nov 29 #Javascript
jquery结合html实现中英文页面切换
Nov 29 #Javascript
基于Three.js插件制作360度全景图
Nov 29 #Javascript
jquery购物车结算功能实现方法
Oct 29 #Javascript
JavaScript微信定位功能实现方法
Nov 29 #Javascript
You might like
PHP 选项及相关信息函数库
2006/12/04 PHP
PHP explode()函数的几个应用和implode()函数有什么区别
2015/11/05 PHP
thinkPHP下的widget扩展用法实例分析
2015/12/26 PHP
jQuery 行级解析读取XML文件(附源码)
2009/10/12 Javascript
jQuery 打造动态下滑菜单实现说明
2010/04/15 Javascript
jQuery.ajax 用户登录验证代码
2010/10/29 Javascript
处理及遍历XML文档DOM元素属性及方法整理
2013/08/23 Javascript
javascript中全局对象的parseInt()方法使用介绍
2013/12/19 Javascript
javascript实现分栏显示小技巧附图
2014/10/13 Javascript
JS实现点击按钮后框架内载入不同网页的方法
2015/05/05 Javascript
js自定义回调函数
2015/12/13 Javascript
JavaScript知识点总结(十六)之Javascript闭包(Closure)代码详解
2016/05/31 Javascript
Node.js 数据加密传输浅析
2016/11/16 Javascript
详解Nodejs基于mongoose模块的增删改查的操作
2016/12/21 NodeJs
使用smartupload组件实现jsp+jdbc上传下载文件实例解析
2017/01/05 Javascript
JQueryEasyUI框架下的combobox的取值和绑定的方法
2017/01/22 Javascript
JQuery中Ajax的操作完整例子
2017/03/07 Javascript
详解如何使用PM2将Node.js的集群变得更加容易
2017/11/15 Javascript
开发用到的js封装方法(20种)
2018/10/12 Javascript
微信小程序实现的五星评价功能示例
2019/04/25 Javascript
vue中解决chrome浏览器自动播放音频和MP3语音打包到线上的实现方法
2020/10/09 Javascript
使用Python的Tornado框架实现一个Web端图书展示页面
2016/07/11 Python
Python实现希尔排序算法的原理与用法实例分析
2017/11/23 Python
python3基于OpenCV实现证件照背景替换
2018/07/18 Python
CSS3教程(1):什么是CSS3
2009/04/02 HTML / CSS
纯CSS3实现运行时钟的示例代码
2021/01/25 HTML / CSS
HTML5实现动画效果的方式汇总
2016/02/29 HTML / CSS
印度网上购物首选目的地:Flipkart
2016/08/01 全球购物
英国领先的隐形眼镜在线供应商:Lenstore.co.uk
2019/11/24 全球购物
Optimalprint加拿大:在线打印服务
2020/04/03 全球购物
2014年社区植树节活动方案
2014/02/28 职场文书
安全技术说明书
2014/05/09 职场文书
小学教师师德师风个人整改措施
2014/09/18 职场文书
高一语文教学反思
2016/02/16 职场文书
高质量“欢迎词”
2019/04/03 职场文书
话题作文之自信作文
2019/11/15 职场文书