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实现给头像加个光芒四射且旋转的背景动画效果
May 07 HTML / CSS
纯CSS3实现8组超炫酷鼠标滑过图片动画
Mar 16 HTML / CSS
使用 css3 实现圆形进度条的示例
Jul 05 HTML / CSS
如何开发一款堪比APP的微信小程序(腾讯内部团队分享)
Dec 22 HTML / CSS
HTML5离线缓存在tomcat下部署可实现图片flash等离线浏览
Dec 13 HTML / CSS
HTML5视频支持检测(检查浏览器是否支持视频播放)
Jun 08 HTML / CSS
html5 input属性使用示例
Jun 28 HTML / CSS
HTML5 canvas画图并保存成图片的jcanvas插件
Jan 17 HTML / CSS
HTML5 移动页面自适应手机屏幕四类方法总结
Aug 17 HTML / CSS
html5 横向滑动导航栏的方法示例
May 08 HTML / CSS
recorder.js 基于Html5录音功能的实现
May 26 HTML / CSS
Canvas如何做个雪花屏版404的实现
Sep 25 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和javascript之间变量的传递实现代码
2012/12/19 PHP
循环 vs 递归浅谈
2013/02/28 Javascript
使用Js让Html中特殊字符不被转义
2013/11/05 Javascript
一个判断抢购时间是否到达的简单的js函数
2014/06/23 Javascript
jquery获取一个元素下面相同子元素的个数代码
2014/07/31 Javascript
24款热门实用的jQuery插件推荐
2014/12/24 Javascript
Javascript基础教程之JavaScript语法
2015/01/18 Javascript
使用AngularJS创建自定义的过滤器的方法
2015/06/18 Javascript
angularjs表格ng-table使用备忘录
2016/03/09 Javascript
限制复选框最多选择项的实现代码
2016/05/30 Javascript
Node.js中看JavaScript的引用
2017/04/22 Javascript
详述 Sublime Text 打开 GBK 格式中文乱码的解决方法
2017/10/26 Javascript
swiper插件自定义切换箭头按钮
2017/12/28 Javascript
vue 中directive功能的简单实现
2018/01/05 Javascript
微信小程序icon组件使用详解
2018/01/31 Javascript
babel的使用及安装配置教程
2018/02/22 Javascript
用p5.js制作烟花特效的示例代码
2018/03/21 Javascript
浅谈VUE防抖与节流的最佳解决方案(函数式组件)
2019/05/22 Javascript
vue中filters 传入两个参数 / 使用两个filters的实现方法
2019/07/15 Javascript
vue 基于abstract 路由模式 实现页面内嵌的示例代码
2020/12/14 Vue.js
python实现爬虫统计学校BBS男女比例之多线程爬虫(二)
2015/12/31 Python
Python基础之getpass模块详细介绍
2017/08/10 Python
Python3导入CSV文件的实例(跟Python2有些许的不同)
2018/06/22 Python
Python中logging.NullHandler 的使用教程
2018/11/29 Python
Django框架orM与自定义SQL语句混合事务控制操作
2019/06/27 Python
使用WingPro 7 设置Python路径的方法
2019/07/24 Python
使用python脚本自动创建pip.ini配置文件代码实例
2019/09/20 Python
opencv调整图像亮度对比度的示例代码
2019/09/27 Python
三步解决python PermissionError: [WinError 5]拒绝访问的情况
2020/04/22 Python
python调用私有属性的方法总结
2020/07/24 Python
Python调用SMTP服务自动发送Email的实现步骤
2021/02/07 Python
施工安全生产承诺书
2014/05/23 职场文书
2015年国税春训心得体会
2015/03/09 职场文书
住房公积金贷款工资证明
2015/06/12 职场文书
幼儿园大班教师随笔
2015/08/14 职场文书
2016秋季幼儿园开学寄语
2015/12/03 职场文书