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 相关文章推荐
纯CSS实现预加载动画效果
Sep 06 HTML / CSS
CSS3 简单又实用的5个属性
Mar 04 HTML / CSS
使用css3匹配手机屏幕横竖状态
Jan 27 HTML / CSS
利用CSS3实现进度条的两种姿势详解
Mar 21 HTML / CSS
深入剖析webstorage[html5的本地数据处理]
Jul 11 HTML / CSS
HTML5 的新的表单元素(datalist/keygen/output)使用介绍
Jul 19 HTML / CSS
用canvas实现图片滤镜效果附演示
Nov 05 HTML / CSS
谷歌浏览器小字体处理方案即12px以下字体
Dec 17 HTML / CSS
html5开发三八女王节表白神器
Mar 07 HTML / CSS
HTML5视频播放插件 video.js介绍
Sep 29 HTML / CSS
canvas拼图功能实现代码示例
Nov 21 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中通过ADO调用Access数据库的方法测试不通过
2006/12/31 PHP
使用TinyButStrong模板引擎来做WEB开发
2007/03/16 PHP
php 上传功能实例代码
2010/04/13 PHP
smarty获得当前url的方法分享
2014/02/14 PHP
php定时执行任务设置详解
2015/02/06 PHP
PHP四种基本排序算法示例
2015/04/09 PHP
php日志函数error_log用法实例分析
2019/09/23 PHP
Centos7安装swoole扩展操作示例
2020/03/26 PHP
6个常见的 PHP 安全性攻击实例和阻止方法
2020/12/16 PHP
ASP.NET jQuery 实例13 原创jQuery文本框字符限制插件-TextArea Counter
2012/02/03 Javascript
javascript动态生成树形菜单的方法
2015/11/14 Javascript
AngularJS实现在ng-Options加上index的解决方法
2016/11/03 Javascript
jQGrid Table操作列中点击【操作】按钮弹出按钮层的实现代码
2016/12/05 Javascript
微信小程序开发之toast提示插件使用示例
2017/06/08 Javascript
Angular 4中如何显示内容的CSS样式示例代码
2017/11/06 Javascript
修改UA在PC中访问只能在微信中打开的链接方法
2017/11/27 Javascript
利用Node.js批量抓取高清妹子图片实例教程
2018/08/02 Javascript
vue-cli的工程模板与构建工具详解
2018/09/27 Javascript
vue组件中节流函数的失效的原因和解决方法
2020/12/02 Vue.js
详解Python的Django框架中manage命令的使用与扩展
2016/04/11 Python
Python 编码Basic Auth使用方法简单实例
2017/05/25 Python
Django Admin实现三级联动的示例代码(省市区)
2018/06/22 Python
python使用knn实现特征向量分类
2018/12/26 Python
Win10里python3创建虚拟环境的步骤
2020/01/31 Python
Keras 利用sklearn的ROC-AUC建立评价函数详解
2020/06/15 Python
python绘制高斯曲线
2021/02/19 Python
一波HTML5 Canvas基础绘图实例代码集合
2016/02/28 HTML / CSS
Html5 页面适配iPhoneX(就是那么简单)
2019/09/05 HTML / CSS
环法自行车赛官方商店:Le Tour de France
2017/08/27 全球购物
WEB控件可以激发服务端事件,请谈谈服务端事件是怎么发生并解释其原理?自动传回是什么?为什么要使用自动传回?
2012/02/21 面试题
我们没有写servlet的构造方法,那么容器是怎么创建servlet的实例呢
2013/04/24 面试题
董事长职责范文
2013/11/08 职场文书
预防传染病方案
2014/06/14 职场文书
学习考察心得体会
2014/09/04 职场文书
2015年计划生育责任书
2015/05/08 职场文书
20180830晚上第一届KSL半决赛 雨神vs解冻(二龙 三炮解说)
2022/04/01 星际争霸