InstantClick.js 让页面提前加载 200ms
加速网站加载的方式有很多,我找到了这个 InstantClick.js,仔细查看了官网的英文文档,发现 InstantClick.js 有个很好的实现思路。
在访问者点击一个链接之前:
- 悬停 hover (hover->click之间200ms左右)
- 鼠标按下 Mousedown (Mousedown->click之间100ms左右)
- Touchstart 手机触碰
这两个事件之间通常有 200ms 的间隔,InstantClick 利用这个时间间隔预加载页面。这样当你点击页面的时候,其实页面已经加载到本地了,呈现当然也就会很快。
当然 InstantClick 也使用了 Pjax: pushState 和 Ajax 技术
同时我试用了下,的确效果不错。如果你的博客需要实现 Pjax,InstantClick 会是个不错的选择。
使用方法
下载 instantclick.js
下载地址:instantclick.min.js 仅仅 2.5Kb 很小。
使用
<script src="instantclick.min.js" data-no-instant></script>
<script data-no-instant>InstantClick.init();</script>
说明:
- data-no-instant 的含义是,这个 JS 只会运行一次,需要根据自己的情况设置
- 如果想避免不必要的预加载,关闭 hover,启用 Mousedown 是个不错的选择,moursedown 意味着已经点击链接
查看效果
打开 Chrome Console,查看 network 视图,会在每次 hover 时,都可以先加载页面,在 Click 时展示结果页面。
兼容性
IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Chrome for Android |
---|---|---|---|---|---|---|---|
10+ | 4.0+ | 5+ | 5.0+ | 11.5+ | 5.0+ | 4.4+ | 18+ |
回调方法
InstantClick 也提供了几个事件可以设置。
- change 页面更改完毕,即 Click 触发加载后
- fetch 页面开始预加载
- receive 页面预加载完毕,即:hover 或 mousedown 触发的预加载,但不一定会 change,因为用户不一定 click
实例
因为使用 ajax,所以 google ga 不会统计PV,所以增加 change 方法
<script src="instantclick.min.js" data-no-instant></script>
<script data-no-instant>
/* Google Analytics code here, without ga('send', 'pageview') */
InstantClick.on('change', function() {
ga('send', 'pageview', location.pathname + location.search);
});
InstantClick.init();
</script>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论