看了《高性能JavaScript》的读书笔记
几个原则:
1、将脚本放在底部
<link>还是在head中,用以保证在js加载前,能加载出正常显示的页面。
<script>放在</body>前。
2、成组脚本
由于每个<script>标签下载时阻塞页面解析过程,所以限制页面的<script>总数也可以改善性能。适用于内联脚本和外部脚本。
3、非阻塞脚本
等页面完成加载后,再加载js代码。也就是,在window.load事件发出后开始下载代码。
(1)defer属性:支持IE4和fierfox3.5更高版本浏览器
<script defer>...</script>
内联和外部文件
带defer属性的<script>可出现在文档的任何位置,对应的js文件将在<script>被解析时启动下载,但代码不会执行,直到DOM加载完毕(在onload事件句柄被调用之前)。所以实现了和也卖弄其他资源一起并行下载。
(2)动态脚本元素
文档对象模型(DOM)允许你使用js动态创建HTML的几乎全部文档内容。
复制代码 代码如下:
var script=document.createElement("script");
script.type="text/javascript";
script.src="/UploadFiles/2021-04-02/file.js">
document.getElementByTagName_r("head")[0].appendChild(script);
此技术的重点在于:无论在何处启动下载,文件额下载和运行都不会阻塞其他页面处理过程。即使在head里(除了用于下载文件的http链接)。
(3)The YUI3 approach
理念:用一个很小的初始代码,下载其余的功能代码,先引入文件:
复制代码 代码如下:
<script type="text/javascript src=//img.jbzj.com/file_images/article/201306/yuanma/combo.js></script>
此种子文件大约10KB,
使用:
复制代码 代码如下:
YUI().use("dom",function(Y){
Y.Dom.addclass(...)
})
当所有代码可用时,回调函数被调用,YUI实例作为参数传入,就可以立即使用新下载的功能。
The LazyLoad library
使用:先引入:lazyload-min.js
(4)
复制代码 代码如下:
LazyLoad.js("a.js",function(){
Appliction.init();
})
多个文件:
复制代码 代码如下:
LazyLoad.js(["a.js","b.js"],function(){
Application.init();
})
(5)The LABjs library
先引入:lab.js
复制代码 代码如下:
$LAB.script("a.js").wait(function(){
Application.init();
})
多个文件,就链式写法
他的独特之处在于能够管理依赖关系。
可以通过wait()函数指定哪些文件应该等待其他文件。
例如:b.js的代码保证不在a.js之前运行
复制代码 代码如下:
$LAB.script("a.js").wait().script("b.js").wait(function(){
Application.init();
})
这样,虽然两个文件是并行下载的,却能保证a.js能在b.js之前执行
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
- 阿杜2024-时光音乐会[金蜂][WAV+CUE]
- 群星《燃!沙排少女 影视原声带》[FLAC/分轨][775.28MB]
- 群星《第6届2010十大发烧唱片精选》2CD [WAV+CUE][1.6G]
- 窦唯1994《黑梦》上海音像首版[WAV分轨][1G]
- 郭子.1996-为爱偷生(载歌载舞歌载戏“极度疯狂”唱作全纪录)【滚石】【WAV+CUE】
- 伍佰.2003-泪桥【艾回】【WAV+CUE】
- 南台湾小姑娘.1996-爱作梦的查某囡仔【大旗】【WAV+CUE】
- 群星《天碟落地-世界[HI-FI] 女声》[WAV分轨][1.1G]
- 黎明《但愿不只是朋友》2022蜚声环球限量版 [WAV+CUE][1G]
- 李玉刚《怀旧辑》玉泽东方[WAV+CUE][1.1G]
- 魔兽世界wlk刺杀贼一键输出宏是什么 wlk刺杀贼一键输出宏介绍
- 魔兽世界wlk战斗贼一键输出宏是什么 wlk战斗贼一键输出宏介绍
- 魔兽世界wlk敏锐贼一键输出宏是什么 wlk敏锐贼一键输出宏介绍
- 李逸朗2007-李威乐[英皇娱乐][WAV+CUE]
- DavidVersace-EyetoEye(2024)[24-44,1]