HTML5资源预加载(Link prefetch)详细介绍(给你的网页加速)


Posted in HTML / CSS onMay 07, 2014

我曾经介绍过本站上使用的一些速度优化技术。而在HTML5里,出现了一个新的用来优化网站速度的新功能:页面资源预加载/预读取(Link prefetch)。

页面资源预加载/预读取(Link prefetch)是什么?来自MDN的解释:

页面资源预加载(Link prefetch)是浏览器提供的一个技巧,目的是让浏览器在空闲时间下载或预读取一些文档资源,用户在将来将会访问这些资源。一个Web页面可以对浏览器设置一系列的预加载指示,当浏览器加载完当前页面后,它会在后台静悄悄的加载指定的文档,并把它们存储在缓存里。当用户访问到这些预加载的文档后,浏览器能快速的从缓存里提取给用户。

简单说来就是:让浏览器预先加载用户访问当前页后极有可能访问的其他资源(页面,图片,视频等)。而且方法超级的简单!

HTML5页面资源预加载(Link prefetch)写法

复制代码
代码如下:

<!-- 预加载整个页面 -->
<link rel="prefetch" href="https://3water.com/misc/3d-album/" /></p> <p><!-- 预加载一个图片 -->
<link rel="prefetch" href=" <a href="https://3water.com/wordpress/">https://3water.com/wordpress/</a>
wp-content/uploads/2014/04/b-334x193.jpg " />

HTML5页面资源预加载/预读取(Link prefetch)功能是通过Link标记实现的,将rel属性指定为“prefetch”,在href属性里指定要加载资源的地址。火狐浏览器里还提供了一种额外的属性支持:
复制代码
代码如下:

<link rel="prefetch alternate stylesheet"
title="Designed for Mozilla" href="mozspecific.css" _fcksavedurl=""mozspecific.css"" />
<link rel="next" href="2.html" />

HTTPS协议资源下也可以使用prefetch。

什么情况下应该预加载页面资源

在你的页面里加载什么样的资源,什么时候加载,这完全取决于你。下面是一些建议:

1.当页面有幻灯片类似的服务时,预加载/预读取接下来的1-3页和之前的1-3页。
2.预加载那些整个网站通用的图片。
3.预加载网站上搜索结果的下一页。

禁止页面资源预加载(Link prefetch)

火狐浏览器里有一个选项可以禁止任何的页面资源预加载(Link prefetch)功能,你可以这样设置:

1.user_pref("network.prefetch-next", false);
2.页面资源预加载(Link prefetch)注意事项

下面是一些关于页面资源预加载(Link prefetch)的注意事项:

1.预加载(Link prefetch)不能跨域工作,包括跨域拉取cookies。
2.预加载(Link prefetch)会污染你的网站访问量统计,因为有些预加载到浏览器的页面用户可能并未真正访问。
3.火狐浏览器从2003年开始就已经提供了对这项预加载(Link prefetch)技术的支持。

利用浏览器空闲时间加载一些额外的资源文件,看起来是既刺激又危险,你想试试这些技术吗?

HTML / CSS 相关文章推荐
带有css3动画效果的兼容多浏览器简单导航条示例
Jan 26 HTML / CSS
纯css3实现的动画按钮的实例教程
Nov 17 HTML / CSS
一款基于css3的列表toggle特效实例教程
Jan 04 HTML / CSS
HTML5 用动画的表现形式装载图像
Mar 08 HTML / CSS
基于HTML5 Canvas 实现弹出框效果
Jun 05 HTML / CSS
探究 canvas 绘图中撤销(undo)功能的实现方式详解
May 17 HTML / CSS
HTML5 Canvas的性能提高技巧经验分享
Jul 02 HTML / CSS
HTML5和以前HTML4的区别整理
Oct 20 HTML / CSS
HTML5 localStorage使用总结
Feb 22 HTML / CSS
前端实现背景虚化但内容清晰且自适应 的实例代码
Aug 01 HTML / CSS
CSS实现漂亮的时钟动画效果的实例代码
Mar 30 HTML / CSS
CSS巧用渐变实现高级感背景光动画
Dec 06 HTML / CSS
HTML5中5个简单实用的API(第二篇,含全屏、可见性、拍照、预加载、电池状态)
May 07 #HTML / CSS
html5 datalist标签使用示例(自动完成组件)
May 04 #HTML / CSS
HTML5 visibilityState属性详细介绍和使用实例
May 03 #HTML / CSS
HTML5中判断用户是否正在浏览页面的方法
May 03 #HTML / CSS
在HTML5 Canvas中放入图片和保存为图片的方法
May 03 #HTML / CSS
HTML5 Canvas+JS控制电脑或手机上的摄像头实例
May 03 #HTML / CSS
一个不错的HTML5 Canvas多层点击事件监听实例
Apr 29 #HTML / CSS
You might like
PHP IN_ARRAY 函数使用注意事项
2010/07/24 PHP
PHP生成不重复随机数的方法汇总
2014/11/19 PHP
PHP从FLV文件获取视频预览图的方法
2015/03/12 PHP
php compact 通过变量创建数组
2016/11/15 PHP
Laravel5.1 框架表单验证操作实例详解
2020/01/07 PHP
jquery异步跨域访问代码
2013/06/28 Javascript
jQuery 全选/反选以及单击行改变背景色实例
2013/07/02 Javascript
使用jquery hover事件实现表格的隔行换色功能示例
2013/09/03 Javascript
input禁止键盘及中文输入,但可以点击
2014/02/13 Javascript
JSON.stringify转换JSON时日期时间不准确的解决方法
2014/08/08 Javascript
JavaScript返回当前会话cookie全部键值对照的方法
2015/04/03 Javascript
js实现网页多级级联菜单代码
2015/08/20 Javascript
Node.js pipe实现源码解析
2017/08/12 Javascript
js移动端事件基础及常用事件库详解
2017/08/15 Javascript
JavaScript继承定义与用法实践分析
2018/05/28 Javascript
layui layer select 选择被遮挡的解决方法
2019/09/21 Javascript
仿照Element-ui实现一个简易的$message方法
2020/09/14 Javascript
[52:14]VG vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
[02:08]2018年度CS GO枪械皮肤设计大赛优秀作者-完美盛典
2018/12/16 DOTA
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
wxPython电子表格功能wx.grid实例教程
2019/11/19 Python
Python变量作用域LEGB用法解析
2020/02/04 Python
PageFactory设计模式基于python实现
2020/04/14 Python
Python3.9.1中使用match方法详解
2021/02/08 Python
css3模拟jq点击事件的实例代码
2017/07/06 HTML / CSS
EGO Shoes美国/加拿大:英国时髦鞋类品牌
2018/08/04 全球购物
绢花、人造花和人造花卉:BLOOM
2019/08/07 全球购物
环境科学专业个人求职的自我评价
2013/11/28 职场文书
儿子婚宴答谢词
2014/01/09 职场文书
音乐教学案例
2014/01/30 职场文书
3分钟英语演讲稿
2014/04/29 职场文书
学校交通安全责任书
2014/08/25 职场文书
档案管理员岗位职责
2015/02/12 职场文书
小学生红领巾广播稿
2015/08/19 职场文书
2016年秋季运动会广播稿
2015/12/21 职场文书
老生常谈 使用 CSS 实现三角形的技巧(多种方法)
2021/04/13 HTML / CSS