InstantClick.js 让页面提前加载 200ms - 文章教程

InstantClick.js 让页面提前加载 200ms

发布于 2019-12-31 字数 2650 浏览 1473 评论 0

加速网站加载的方式有很多,我找到了这个 InstantClick.js,仔细查看了官网的英文文档,发现 InstantClick.js 有个很好的实现思路。

InstantClick.js 让页面提前加载 200ms

在访问者点击一个链接之前:

  • 悬停 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 也提供了几个事件可以设置。

  1. change 页面更改完毕,即 Click 触发加载后
  2. fetch 页面开始预加载
  3. 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>

如果你对这篇文章有疑问,欢迎到本站 社区 发帖提问或使用手Q扫描下方二维码加群参与讨论,获取更多帮助。

扫码加入群聊

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

目前还没有任何评论,快来抢沙发吧!

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

2583 文章
29 评论
84935 人气
更多

推荐作者

猫性小仙女

文章 1 评论 0

qq_VO6LhT

文章 0 评论 0

猿舌电影

文章 0 评论 0

7556275422

文章 0 评论 0

YYQ_139

文章 0 评论 0