一、前言                            

在《JS魔法堂:jsDeferred源码剖析》中我们了解到img元素加载失败可以作为函数异步执行的优化方案,本文打算对img元素的加载行为进行更深入的探讨。

二、资源加载的相关属性和事件                  

资源加载首先当然是确定资源位置的 src属性 、随之就是资源加载成功与否的 onload事件 和 onerror事件 ,对于IE5~10来说还多了一个 onreadystatechage事件 和与该事件相关联的 readyState属性 和 complete属性 。

onload事件 ,当资源加载完成并成功解析后触发(若加载的不是image/*类型的资源,则解析失败)。

onerror事件 ,当找不到资源或解析失败后触发。

onreadystatechange事件 ,在onload事件后触发。

readyState属性 ,用于表示IMG元素当前的资源装载状态,默认值为"uninitialized",onload事件触发后变为"complete"(onload事件处理函数运行时,readyState依然为"uninitialized")。

complete属性 ,用于表示IMG元素的资源是否成功解析。默认为false,,onload事件触发后变为true(onload事件处理函数运行时,readyState依然为false)。

src属性 ,用于指定资源位置URI。常见的URI格式为 http://..... 、 https://... 、 javascript:... 和 data:image/*,... 。而不同的浏览器对不同的URI支持程度和行为均有所差异。关于URI的资讯可以参考:URI SchemeUniform resource identifier

三、实验开始                          

本次实验将创建 img元素 并对其的 src属性 分别赋予以下内容 fsjohnhuang.png 、 : 、 空字符串 、 空白字符串 、  和 data:image/png,foo ,并订阅img元素的onload和onerror事件,IE5~10下还订阅了onreadystatechange事件,统计整理其在IE5~11、Chrome和FF下的行为特点和事件响应延时。具体实验统计如下:

测试环境

  1.测试页面地址为http://localhost:9000/test.html

 2. 图片fsjohnhuang.png的大小为12KB

  符号说明:

N/A 表示该列事件不触发。

src属性值 备注 Chrome FireFox IE5~11
onload事件 onerror事件 备注 onload事件 onerror事件 备注 onload事件 onerror事件

IE5~10

on

ready

state

change

备注
fsjohnhuang.png

有效URI,

URI自动补全为

http://localhost

:9000/fsjohnhu

ang.png

首次请求延时为2~5ms N/A

1.发起资源请求;

2.由于对资源进行缓存,后续对同一资源的请求,延时为0~1ms

首次请求延时为4~10ms N/A

1.发起资源请求;

2.由于对资源进行缓存,后续对同一资源的请求,延时为0~1ms

首次请求延时为3~9ms N/A 发生在onload事件之后

1.发起资源请求;

2.由于对资源进行缓存,后续对同一资源的请求,延时为0~1ms

:0

无效URI,

URI自动补全为http://localhost

:9000/:0

若IMG元素

在渲染树中,

则会显示加载

失败的示意图。

N/A 延时为5~300+ms  1.发起资源请求 N/A 延时为16~60ms  1.发起资源请求 N/A 首次请求延时为16ms左右 N/A

1.发起资源请求;

2.由于对资源进行缓存,后续对同一资源的请求,延时为0~1ms

空字符串,"" 无效URI N/A 延时为0~1ms

1.不发起资源请求;

2. 若IMG元素在渲染树中,不显示加载失败的示意图。

N/A N/A 

1.不发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A  延时为0~1ms N/A 

1.不发起资源请求;

2. 若IMG元素在渲染树中,不显示加载失败的示意图。

空白字符串,"    " 无效URI N/A 延时为0~1ms 

1.不发起资源请求;

2. 若IMG元素在渲染树中,不显示加载失败的示意图。

N/A 延时为16~60ms 

1.发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A 首次延时为14ms左右   N/A

1.发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图;

3. 由于对资源进行缓存,后续对同一资源的请求,延时为0~1ms

//:0 无效URI,会自动补全为http://:0/ N/A  延时为0~1ms

1.不发起资源请求;

2. 若IMG元素在渲染树中,不显示加载失败的示意图。

N/A  延时为0~1ms 

1.不发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A   延时为0~1ms N/A 

1.发起资源请求,但会被浏览器取消掉(No Server Hits);

2. 若IMG元素在渲染树中,显示加载失败的示意图。

javascript:void 0 无效的JavaScript URI Scheme N/A  延时为1~2ms

1.发起资源请求,但会被浏览器取消掉(No Server Hits);

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A  延时为1~2ms

1.发起资源请求,但会被浏览器取消掉(No Server Hits);

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A  N/A N/A 

1.通过JS执行img.src=

"javascript:void 0"会报"拒绝访问"的异常。假如通过$.html()或静态html方式设置src为javascript:void 0,则不会报该异常。

data:image/png,f

无效的Data URI Scheme

N/A 延时0~1ms 

1.不会发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A 延时为1~2ms 

1.不会发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

N/A  延时0~1ms N/A 

1.不会发起资源请求;

2. 若IMG元素在渲染树中,显示加载失败的示意图。

由上述统计数据可知,在Chrome、FF和IE中行为比较同一的是加载无效DataURI Scheme。延时也比较短且稳定。因此jsDeffered采用此方式来为异步执行提速!

四、总结                            

这里仅仅对IMG元素加载http、javascript和data的URI Scheme等进行实验,加上实验手段等问题,难免导致统计数据不全面,若有纰漏希望大家指正,谢谢。

尊重原创,转载请注明来自:http://www.cnblogs.com/fsjohnhuang/p/4148933.html ^_^肥子John

五、参考                            

http://www.w3help.org/zh-cn/causes/BX9021

http://stackoverflow.com/questions/5775469/whats-the-valid-way-to-include-an-image-with-no-src

JS魔法堂:IMG元素加载行为详解的更多相关文章

  1. C编译器、链接器、加载器详解

    摘自http://blog.csdn.net/zzxian/article/details/16820035 C编译器.链接器.加载器详解 一.概述 C语言的编译链接过程要把我们编写的一个c程序(源代 ...

  2. jquery插件图片延时加载实例详解

    效果预览:http://keleyi.com/keleyi/phtml/image/index.htm 使用方法:1.导入JS插件 <script src="http://keleyi ...

  3. web.xml加载顺序详解

    一. 1.启动tomcat启动web项目,首先读取web.xml文件中<context-param>和<listener> 2.容器创建一个ServletContext(ser ...

  4. openlayers 加载瓦片详解 一

    在这先说点题外话,本人在研究webgl 三维球过程中惊人发现,openlayers 的开发人员也在研究webgl并经证实他们也正在研发基于 webgl的三维gis开源平台,这可能是首个开源的三维平台, ...

  5. Spring Cloud Alibaba基础教程:Nacos配置的加载规则详解

    前情回顾: <Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现> <Spring Cloud Alibaba基础教程:支持的几种服务消费方式(Res ...

  6. Android学习笔记_50_(转 四种加载方式详解(standard singleTop singleTask singleInstance)

    Android之四种加载方式 (http://marshal.easymorse.com/archives/2950 图片) 在多Activity开发中,有可能是自己应用之间的Activity跳转,或 ...

  7. Javascript在浏览器中的加载顺序详解!

    现在前端用javascript用的比较多,当然真心的说这个语言是一个非常业余的语言,但是用的人很多,所以也比较火.今天想完成一个javascript外部文件自动加载的设计(类似于java或者php的i ...

  8. servlet与filter的加载顺序详解

     项目:3个filter,3个servlet,匹配的url路径/hello. 情况1:servlet没加<load-on-startup></load-on-startup>情 ...

  9. mybatis加载配置文件详解

    spring整合Mybatis后,SqlSessionFactory的创建由spring进行了代理,以下是SqlSessionFactory创建的流程 SqlSessionFactoryBean: p ...

随机推荐

  1. 我的ORM之八-- 事件

    我的ORM索引 dbo.Event 需要新建一个类,继承:IDboEvent,并设置给:dbo.Event,如: dbo.Event = MyOqlEvent.GetInstance(); 在 IDb ...

  2. EF(Linq)框架使用过程中的小技巧汇总

    这篇博客总结本人在实际项目中遇到的一些关于EF或者Linq的问题,作为以后复习的笔记或者供后来人参考(遇到问题便更新). 目录 技巧1: DbFunctions.TruncateTime()的使用 技 ...

  3. 【腾讯bugly干货分享】Android自绘动画实现与优化实战——以Tencent OS录音机波形动

    前言 本文为腾讯bugly的原创内容,非经过本文作者同意禁止转载,原文地址为:http://bugly.qq.com/bbs/forum.php?mod=viewthread&tid=1180 ...

  4. 里氏替换原则(Liskov Substitution Principle)

    开放封闭原则(Open Closed Principle)是构建可维护性和可重用性代码的基础.它强调设计良好的代码可以不通过修改而扩展,新的功能通过添加新的代码来实现,而不需要更改已有的可工作的代码. ...

  5. 【读书笔记】Html5游戏开发

    一直对HMTL5做游戏饶有兴趣,而这本书刚好就是HTML5 2游戏初级入门的书.Demo简单注释详细,可以拿来练练手,一个星期左右就可以读完.若要追求酷炫高大上效果,这本书恐怕要让你失望了.但作为上手 ...

  6. ASP.NET一般处理程序访问Session问题

    我们在使用一般处理程序的时候,访问Session会出现如下错误: 解决方案如下: //引用命名空间 using System.Web.SessionState; //继承IRequiresSessio ...

  7. Unity3D热更新全书-脚本(一) 初识脚本

    开篇之前还是要先说明,这是一份给经验并不丰富的程序员阅读的文字. 有需求.有疑惑,往下看. 第一个问题什么是脚本?程序和脚本如何区分?我们给Unity编写的组件是程序还是脚本? 这些问题本文无意去解答 ...

  8. 用DirectX实现魔方(二)

    这篇说一下如何构造魔方,主要包括魔方几何体的构造及纹理贴图.以下论述皆以三阶魔方为例,三阶魔方共有3 x 3 x 3 = 27个小立方体. 构造魔方 在第一篇里面说过,最初模型用的是微软的.x文件格式 ...

  9. php操作xml

    最近计划写个人的小网站,一系列原因选择了用php来写,最大的问题就是虽然php很流行,但我从来没有接触过php,看了一个多星期的基本语法后做些小练习热热身,但是期间是各种问题啊,主要是对php不熟悉, ...

  10. [备忘]删除SQL Server中无登录名的用户

    这个问题通常会在还原虚拟主机的备份SQL文件后发生,原先在虚拟主机上的用户会被还原到本地,但是本地没有权限对其进行操作. SELECT N'ALTER AUTHORIZATION ON SCHEMA: ...