不要什么都依赖JavaScript。不要编写重复性的脚本。要把JavaScript当作糖果工具,只是起到美化作用。别给你的网站添加大量的JavaScript代码。只有必要的时候用一下。只有确实能改善用户体验的时候用一下。
尽量减少DOM访问
使用JavaScript访问DOM元素很容易,代码更容易阅读,但是速度很慢。下面介绍几个要点:限制使用JavaScript来修饰网页布局,把针对访问元素的引用缓存起来。有时,当你的网站依赖大量的DOM改动时,就应该考虑限制你的标记。这是改用HTML5、舍弃那些原来的XHTML和HTML4的一个充分理由。你可以查看DOM元素的数量,只要在Firebug插件的控制台中输入:document.getElementsByTagName('*').length。
压缩代码
要提供经过压缩的JavaScript页面,最有效的办法就是先用JavaScript压缩工具对你的代码压缩一下,这种压缩工具可以压缩变量和参数名称,然后提供因而获得的代码,使用了gzip压缩。
是的,我没有压缩我的main.js,但你要检查有没有未经压缩的任何jQuery插件,别忘了压缩。下面我列出了压缩方面的几个方案。
◆ YUI压缩工具(jQuery开发团队就使用它),初学者指南
(http://www.slideshare.net/nzakas/extreme-JavaScript-compression-with-yui-compressor)、第二指南 (http://vilimpoc.org/research/js-speedup/)和官方网站(http://developer.yahoo.com/yui/compressor/)。
◆ Dean Edwards Packer(http://dean.edwards.name/packer/)
◆ JSMin(http://crockford.com/JavaScript/jsmin)
GZip压缩:其背后的想法是,缩短在浏览器和服务器之间传送数据的时间。缩短时间后,你得到标题是Accept-Encoding: gzip,deflate的一个文件。不过这种压缩方法有一些缺点。它在服务器端和客户端都要占用处理器资源(以便压缩和解压缩),还要占用磁盘空间。
避免eval():虽然有时eval()会在时间方面带来一些效率,但使用它绝对是错误的做法。eval()导致你的代码看起来更脏,而且会逃过大多数压缩工具的压缩。
加快JavaScript装入速度的工具:Lab.js
有许多出色的工具可以加快JavaScript装入的速度。值得一提的一款工具是Lab.js。
借助LAB.js(装入和阻止JavaScript),你就可以并行装入JavaScript文件,加快总的装入过程。此外,你还可以为需要装入的脚本设置某个顺序,那样就能确保依赖关系的完整性。此外,开发者声称其网站上的速度提升了2倍。
使用适当的CDN
现在许多网页使用内容分发网络(CDN)。它可以改进你的缓存机制,因为每个人都可以使用它。它还能为你节省一些带宽。你很容易使用ping检测或使用Firebug调试那些服务器,以便搞清可以从哪些方面加快数据的速度。选择CDN时,要照顾到你网站那些访客的位置。记得尽可能使用公共存储库。
面向jQuery的几个CDN方案:
◆ http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js——谷歌Ajax,关于更多库的信息请参阅http://code.google.com/apis/libraries/devguide.html#Libraries。
◆ http://ajax.microsoft.com/ajax/jquery/jquery-1.4.2.min.js——微软的CDN
•http://code.jquery.com/jquery-1.4.2.min.js——Edgecast (mt)。
网页末尾装入JavaScript
如果你关注用户,用户因互联网连接速度慢而没有离开你的网页,这是一个非常好的做法。易用性和用户放在首位,JavaScript放在末位。这也许很痛苦,但是你应该有所准备,有些用户会禁用JavaScript。可以在头部分放置需要装入的一些JavaScript,但是前提是它以异步方式装入。
异步装入跟踪代码
这一点非常重要。我们大多数人使用谷歌分析工具(Google Analytics)来获得统计数据。这很好。现在看一下你把你的跟踪代码放在哪里。是放在头部分?还是说它使用document.write?然后,如果你没有使用谷歌分析工具异步跟踪代码,那也只能怪你自己。
Google Analytics 비동기 추적 코드는 다음과 같습니다. 우리는 document.write를 사용하는 대신 DOM을 사용한다는 점을 인정해야 하며, 이는 사용자에게 더 적합할 수 있습니다. 웹페이지가 로드되기 전에 이러한 이벤트 중 일부를 감지할 수 있으며 이는 매우 중요합니다. 이제 이 상황을 생각해 보세요. 페이지가 로드되지도 않았고 모든 사용자가 페이지를 닫았습니다. 누락된 페이지 조회수에 대한 해결책을 찾았습니다.
Ajax 최적화
Ajax 요청은 웹사이트 성능에 상당한 영향을 미칩니다. 아래에서는 Ajax 최적화에 대한 몇 가지 핵심 사항을 소개합니다.
Ajax 캐시
먼저 코드를 살펴보세요. Ajax는 캐시 가능합니까? 예, 데이터에 의존하지만 대부분의 Ajax 요청은 캐시 가능해야 합니다. jQuery에서는 스크립트 및 jsonp 데이터 유형을 제외하고 요청이 기본적으로 캐시됩니다.
Ajax 요청에는 GET 사용
POST 유형 요청에는 두 개의 TCP 패킷(헤더 먼저, 그 다음 데이터)을 보내야 합니다. GET 유형 요청은 하나의 패킷만 보내면 됩니다(이는 보유한 쿠키 수에 따라 달라질 수 있음). 따라서 URL 길이가 2K 미만이고 일부 데이터를 요청하려는 경우 GET을 사용할 수도 있습니다.
ySlow 사용
성능 측면에서 ySlow는 간단하면서도 매우 효과적입니다. 웹 사이트에 점수를 매겨 수정이 필요한 영역과 집중해야 할 영역을 표시합니다.
또 다른 요령: JavaScript를 PNG 파일로 패키징하는 것입니다.
JS와 CSS를 이미지 끝에 추가한 다음 CSS로 자르고 단일 HTTP 요청으로 애플리케이션에 필요한 모든 정보를 얻는다고 상상해 보세요.
최근에 이 방법을 찾았어요. 기본적으로 JavaScript/css 데이터를 PNG 파일로 압축합니다. 그런 다음 압축을 풀고 캔버스 API의 getImageData()를 사용하면 됩니다. 게다가 매우 효율적입니다. 데이터를 축소하지 않고도 약 35% 더 압축할 수 있습니다. 그리고 이는 무손실 압축입니다. 더 큰 스크립트의 경우 이미지가 캔버스를 가리키고 픽셀을 읽는 동안 "약간의" 로딩 시간이 있다는 것을 느낄 것입니다.
영문 원문 : http://www.1stwebdesigner.com/design/load-JavaScript-faster/