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

发布于 2019-12-31 20:15:46 字数 2258 浏览 1932 评论 0

加速网站加载的方式有很多,我找到了这个 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 时展示结果页面。

兼容性

IEFirefoxChromeSafariOperaiOS SafariAndroid BrowserChrome 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>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

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

0 文章
0 评论
84960 人气
更多

推荐作者

沧笙踏歌

文章 0 评论 0

山田美奈子

文章 0 评论 0

佚名

文章 0 评论 0

岁月无声

文章 0 评论 0

暗藏城府

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文