前端性能优化准则:

一、减少http请求。
    措施:合并小图片,css控制背景图。合并CSS,合并JS
二、使用CDN(Content Deliver Network 内容分发网络)发布静态资源。
三、启用压缩组件。
    response header:Content-encoding
    request header:Accept-encoding
四、添加Expires响应头。
    response header:Expires(指定过期时间)
    缺点:1.需要指定具体的过期日期,时间到后需要重新指定。2.服务端客户端时钟必须一致。 
    http 1.1 引入Cache-Control:max-age 指定秒数解决该问题。
    
五、head 引入样式文件。
    解决:白屏,闪屏问题。浏览器加载无样式DOM有两种策略:
    1、先渲染无样式dom树,发现样式文件后重新加载,引起闪屏问题。
    2、延迟渲染dom树直到发现样式文件,加载完样式文件后再加载dom树,引起白屏问题。
六、底部引入脚本文件。
    早期浏览器(IE67),JS文件的下载会禁用浏览器的并行下载特性(http 1.1 规定浏览器可同时发起2个http链接),IE8以后浏览器可以并行下载多个脚本,但是由于并发的http连接数是有限的,所以依然会阻塞其它资源的下载,原因:
1、浏览器无法判断脚本中是否有document.write改变dom结构。
2、浏览器为了保证脚本的执行顺序。
    脚本的并行下载是必要的,但必须保证执行顺序,保证执行顺序的措施:
1、IE浏览器的defer属性 
2、动态创建script dom,并同时绑定onload,onreadystatechange(IE浏览器不支持onload,需要同时判断script dom的readyState的是是否等于loaded或者complate,有时候状态值会不经过loaded状态直接变为complete,而有时候变为loaded后并不切换到complate)事件。
3、document.write 脚本
七、精简CSS 脚本。
八、删除重复脚本。
九、减少DNS查询。
技巧:使用link标签的ref="dns-prefetch"类型,用于提前dns解析和缓存域名主机信息,以确保将来再请求同域名的资源时能够节省dns查找时间。例如淘宝主页:
十、自定义Etag。
    Etag的格式与web容器是耦合的,站点在服务器集群(多种web容器)下导致Etag值不一致,命中率很低。两种方案:
    1、禁用Etag
    2、自定义Etag
十一、缓存Ajax
 
下面这篇文章提供了不一样的思路来优化浏览器对静态资源的加载,比如利用LocalStorage缓存文件,link标签预加载资源等:
http://www.infoq.com/cn/articles/browser-resource-loading-optimization?utm_source=infoq&utm_medium=popular_links_homepage
 
非阻塞式加载脚本技术对比:
http://www.cnblogs.com/yslow/archive/2009/04/28/1445597.html

构建高性能JavaScript应用的更多相关文章

  1. 《高性能javascript》一书要点和延伸(上)

    前些天收到了HTML5中国送来的<高性能javascript>一书,便打算将其做为假期消遣,顺便也写篇文章记录下书中一些要点. 个人觉得本书很值得中低级别的前端朋友阅读,会有很多意想不到的 ...

  2. 《高性能javascript》 领悟随笔之-------DOM编程篇(二)

    <高性能javascript> 领悟随笔之-------DOM编程篇二 序:在javaSctipt中,ECMASCRIPT规定了它的语法,BOM实现了页面与浏览器的交互,而DOM则承载着整 ...

  3. 《构建高性能web站点》随笔 无处不在的性能问题

    前言– 追寻大牛的足迹,无处不在的“性能”问题. 最近在读郭欣大牛的<构建高性能Web站点>,读完收益颇多.作者从HTTP.多级缓存.服务器并发策略.数据库.负载均衡.分布式文件系统多个方 ...

  4. 高性能JavaScript 重排与重绘

    先回顾下前文高性能JavaScript DOM编程,主要提了两点优化,一是尽量减少DOM的访问,而把运算放在ECMAScript这一端,二是尽量缓存局部变量,比如length等等,最后介绍了两个新的A ...

  5. 【原文】前端程序员必须知道的高性能Javascript知识

    原文:前端程序员必须知道的高性能Javascript知识 想必大家都知道,JavaScrip是全栈开发语言,浏览器,手机,服务器端都可以看到JS的身影. 本文会分享一些高效的JavaScript的最佳 ...

  6. 构建高性能web站点--读书大纲

    用户输入你的站点网址,等了半天..还没打开,裤衩一下就给关了.好了,流失了一个用户.为什么会有这样的问题呢.怎么解决自己站点“慢”,体验差的问题呢. 在这段等待的时间里,到底发生了什么?事实上这并不简 ...

  7. 高性能javascript

    高性能javascript开发 标签(空格分隔): javascript DOM访问与修改 访问DOM元素是具有代价的,修改元素代价较为昂贵,会导致浏览器重新计算页面的几何变化. 尽量减少DOM访问, ...

  8. 【原创】构建高性能ASP.NET站点之二 优化HTTP请求(前端)

    原文:[原创]构建高性能ASP.NET站点之二 优化HTTP请求(前端) 构建高性能ASP.NET站点之二 优化HTTP请求(前端) 前言: 这段时间比较的忙,文章写不是很勤,希望大家谅解. 上一篇文 ...

  9. 《高性能javascript》学习总结

    本文是学习<高性能javascript>(Nichols C. Zakes著)的一些总结,虽然书比较过时,里面的知识点也有很多用不上了,但是毕竟是前人一步步探索过来的,记录着javascr ...

随机推荐

  1. css 雪碧图

    CSS Sprites在国内很多人叫css精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问 该页面时,载入的图片就不会像以前那样一幅一幅地 ...

  2. IoC概述

    ---------------siwuxie095 IoC,即 Inversion of Control,控制反转,它是 Spring 容器的内核 AOP.声明式事务等功能都是在此基础上开花结果,即 ...

  3. p2371&bzoj2118 墨墨的等式

    传送门(bzoj) 题目 墨墨突然对等式很感兴趣,他正在研究a1x1+a2y2+…+anxn=B存在非负整数解的条件,他要求你编写一个程序,给定N.{an}.以及B的取值范围,求出有多少B可以使等式存 ...

  4. solr搜索应用

    非票商品搜索,为了不模糊查询影响数据库的性能,搭建了solr搜索应用,php从solr读取数据

  5. 做c语言的码农专业发展方向

    写了几年C语言代码,最近在思索,何去何从比较好? 搜索了一下,发现几个答案: 2015年10月编程语言排行榜 丢开C语言在教学应用外.在目前C语言的实际应用中.常见的应用的情景有如下: 内核/驱动,b ...

  6. 关于奇异值分解(SVD)的理解

    奇异值分解实际上是将一个矩阵,分解成为两个不同维度(行数和列数)上的正交向量集之间的映射变换,奇异值则是变换时的缩放! 例如上面的矩阵M就是一个5维映射到4维的变换矩阵,而SVD分解得到的奇异值和奇异 ...

  7. jQuery :odd 选择

    <!DOCTYPE html><html><head><meta charset="utf-8"><script src=&q ...

  8. C# 写 LeetCode easy #27 Remove Element

    27. Remove Element Given an array nums and a value val, remove all instances of that value in-place  ...

  9. Spark 官网提到的几点调优

    1. 数据序列化 默认使用的是Java自带的序列化机制.优点是可以处理所有实现了java.io.Serializable 的类.但是Java 序列化比较慢. 可以使用Kryo序列化机制,通常比Java ...

  10. HTML常用标签与CSS基础知识

    一.HTML页面结构 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> ...