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 border-image详解、应用及jQuery插件
Aug 29 HTML / CSS
CSS3实现超酷的黑猫警长首页
Apr 26 HTML / CSS
轻松掌握CSS3中的字体大小单位rem的使用方法
May 24 HTML / CSS
css3 flex实现div内容水平垂直居中的几种方法
Mar 27 HTML / CSS
HTML5之web workers_动力节点Java学院整理
Jul 17 HTML / CSS
HTML5 video视频字幕的使用和制作方法
May 03 HTML / CSS
浅谈pc和移动端的响应式的使用
Jan 03 HTML / CSS
html5唤起app的方法
Nov 30 HTML / CSS
微信html5页面调用第三方位置导航的示例
Mar 14 HTML / CSS
recorder.js 基于Html5录音功能的实现
May 26 HTML / CSS
css3 实现文字闪烁效果的三种方式示例代码
Apr 25 HTML / CSS
关于html选择框创建占位符的问题
Jun 09 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(4) php 函数 补充2
2010/02/15 PHP
浅析虚拟主机服务器php fsockopen函数被禁用的解决办法
2013/08/07 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
2014/09/10 PHP
PHP使用ActiveMQ实例
2018/02/05 PHP
JavaScript 学习笔记(九)call和apply方法
2010/01/11 Javascript
新老版本juqery获取radio对象的方法
2010/03/01 Javascript
JavaScript中toString()方法的使用详解
2015/06/05 Javascript
JS实现仿QQ效果的三级竖向菜单
2015/09/25 Javascript
JavaScript表单验证实例之验证表单项是否为空
2016/01/10 Javascript
Ajax异步获取html数据中包含js方法无效的解决方法
2017/02/20 Javascript
js获取json中key所对应的value值的简单方法
2020/06/17 Javascript
angularjs结合html5实现拖拽功能
2018/06/25 Javascript
vuejs+element UI点击编辑表格某一行时获取内容填入表单的示例
2018/10/31 Javascript
vue-父子组件和ref实例详解
2019/11/10 Javascript
vue-cli设置publicPath小记
2020/04/14 Javascript
Ant-design-vue Table组件customRow属性的使用说明
2020/10/28 Javascript
[01:39]2014DOTA2国际邀请赛 Newbee经理CU专访队伍火力全开
2014/07/15 DOTA
Python 可爱的大小写
2008/09/06 Python
Python正则抓取网易新闻的方法示例
2017/04/21 Python
Python元字符的用法实例解析
2018/01/17 Python
5个很好的Python面试题问题答案及分析
2018/01/19 Python
基于python if 判断选择结构的实例详解
2019/05/06 Python
pyqt 多窗口之间的相互调用方法
2019/06/19 Python
pytorch 加载(.pth)格式的模型实例
2019/08/20 Python
pandas的resample重采样的使用
2020/04/24 Python
Python实现在线批量美颜功能过程解析
2020/06/10 Python
Python3爬虫中关于Ajax分析方法的总结
2020/07/10 Python
编写一个类体现构造,公有,私有方法,静态,私有变量
2013/08/10 面试题
环境工程与管理大学毕业生求职信
2013/10/02 职场文书
情况说明书格式范文
2014/05/06 职场文书
科学发展观活动总结
2014/08/28 职场文书
2015社区爱国卫生工作总结
2015/04/21 职场文书
代理词怎么写
2015/05/25 职场文书
出纳2015年度工作总结范文
2015/10/14 职场文书
学校标语口号大全
2015/12/26 职场文书
Redis高级数据类型Hyperloglog、Bitmap的使用
2021/05/24 Redis