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创建动态菜单效果
Jul 10 HTML / CSS
全方位了解CSS3的Regions扩展
Aug 07 HTML / CSS
利用CSS3实现的文字定时向上滚动
Aug 29 HTML / CSS
用纯CSS3实现网页中常见的小箭头
Oct 16 HTML / CSS
利用CSS3 动画 绘画 圆形动态时钟
Mar 20 HTML / CSS
HTML5实现预览本地图片
Feb 17 HTML / CSS
详解HTML5 Canvas绘制不规则图形时的非零环绕原则
Mar 21 HTML / CSS
基于html5绘制圆形多角图案
Apr 21 HTML / CSS
HTML5新特性 多线程(Worker SharedWorker)
Apr 24 HTML / CSS
HTML5实现音频和视频嵌入的方法
Aug 22 HTML / CSS
canvas生成带二维码海报的踩坑记录
Sep 11 HTML / CSS
html2canvas生成的图片偏移不完整的解决方法
May 19 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
Fatal error: session_start(): Failed to initialize storage module: files问题解决方法
2014/05/04 PHP
PHP使用get_headers函数判断远程文件是否存在的方法
2014/11/28 PHP
php实现的双色球算法示例
2017/06/20 PHP
浅析PHP中的 inet_pton 网络函数
2019/12/16 PHP
解决FLASH需要点击激活的代码
2006/12/20 Javascript
JavaScript中Math对象使用说明
2008/01/16 Javascript
JavaScript 图片预览效果 推荐
2009/12/22 Javascript
javascript 图片上一张下一张链接效果代码
2010/03/12 Javascript
基于jquery实现的鼠标拖拽元素复制并写入效果
2011/08/23 Javascript
js实现连续英文字符自动换行兼容ie6 ie7和firefox
2013/09/06 Javascript
自定义函数实现IE7与IE8不兼容js中trim函数的问题
2015/02/03 Javascript
js实现单击图片放大图片的方法
2015/02/17 Javascript
全面了解函数声明与函数表达式、变量提升
2016/08/09 Javascript
js实现图片淡入淡出切换简易效果
2016/08/22 Javascript
angular.js中解决跨域问题的三种方式
2017/07/12 Javascript
深入理解ES6的迭代器与生成器
2017/08/19 Javascript
Vue使用vue-draggable 插件在不同列表之间拖拽功能
2020/03/12 Javascript
关于JavaScript数组去重的一些理解汇总
2020/09/10 Javascript
js实现随机圆与矩形功能
2020/10/29 Javascript
python通过pil模块获得图片exif信息的方法
2015/03/16 Python
Python中read()、readline()和readlines()三者间的区别和用法
2017/07/30 Python
python中while和for的区别总结
2019/06/28 Python
Python 3.8 新功能全解
2019/07/25 Python
2020新版本pycharm+anaconda+opencv+pyqt环境配置学习笔记,亲测可用
2020/03/24 Python
Python logging模块异步线程写日志实现过程解析
2020/06/30 Python
python实现录制全屏和选择区域录屏功能
2021/02/05 Python
python实现简单文件读写函数
2021/02/25 Python
前端实现背景虚化但内容清晰且自适应 的实例代码
2019/08/01 HTML / CSS
The North Face北面法国官网:美国著名户外品牌
2019/11/01 全球购物
华为智利官方商店:Huawei Chile
2020/05/09 全球购物
核心价值观演讲稿
2014/05/13 职场文书
2014年卫生工作总结
2014/11/27 职场文书
先进教育工作者事迹材料
2014/12/23 职场文书
培训计划通知
2015/07/15 职场文书
社交电商模式的兴起:这些新的商机千万别错过
2019/07/26 职场文书
在Centos 8.0中安装Redis服务器的教程详解
2022/03/21 Redis