我正在追求达到100/100的PageSpeed,我几乎在那里。我试图找到一个很好的解决方案来缓存谷歌分析。

这是我得到的信息:

利用浏览器缓存 在静态资源的HTTP报头中设置过期日期或最大年龄指示浏览器从本地磁盘加载以前下载的资源,而不是通过网络。 利用浏览器缓存以下可缓存资源: http://www.google-analytics.com/analytics.js(2小时)

我找到的唯一解决方案是2012年的,我不认为这是一个好的解决方案。本质上,您复制GA代码并自己托管它。然后运行cron作业,每天重新检查谷歌一次,以获取最新的GA代码并替换它。

http://diywpblog.com/leverage-browser-cache-optimize-google-analytics/

我还能做什么来达到100/100,同时也使用谷歌分析?

谢谢你!


当前回答

根据你对谷歌Analytics数据的使用,如果你想要基本信息(比如访问量、UI交互),你可能根本不需要包含Analytics .js,但仍然可以在GA中收集数据。

一种选择可能是在缓存的脚本中使用度量协议。 谷歌分析:测量协议概述

当您显式地将传输方法设置为image时,您可以看到GA如何构造自己的图像信标。

ga('set', 'transport', 'image');

https://www.google-analytics.com/r/collect
  ?v={protocol-version}
  &tid={tracking-id}
  &cid={client-id}
  &t={hit-type}
  &dl={location}

您可以使用所需的有效负载创建自己的GET或POST请求。

但是,如果你需要更详细的内容,那就不值得你这么做了。

其他回答

2020年,Page Speed Insights用户代理为:移动端“Chrome-Lighthouse”和桌面端“谷歌Page Speed Insights”。

<?php if (!isset($_SERVER['HTTP_USER_AGENT']) || stripos($_SERVER['HTTP_USER_AGENT'], 'Chrome-Lighthouse') === false  || stripos($_SERVER['HTTP_USER_AGENT'], 'Google Page Speed Insights') === false): ?>
// your google analytics code and other external script you want to hide from PageSpeed Insights here
<?php endif; ?>

varvy.com(100/100谷歌页面速度洞察)只在用户滚动页面时才加载谷歌分析代码:

var fired = false;

window.addEventListener("scroll", function(){
    if ((document.documentElement.scrollTop != 0 && fired === false) || (document.body.scrollTop != 0 && fired === false)) {

        (function(i,s,o,g,r,a,m{i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)})(window,document,'script','//www.google-analytics.com/analytics.js','ga');

        ga('create', 'UA-XXXXXXXX-X', 'auto');
        ga('send', 'pageview');

        fired = true;
    }
}, true);

要修复此问题,您必须在本地下载文件并运行cron作业以保持更新。注意:这不会让你的网站更快,所以最好忽略它。

但是,为了演示目的,请遵循以下指南: http://diywpblog.com/leverage-browser-cache-optimize-google-analytics/

您可以尝试在本地托管analysis .js,并使用缓存脚本或手动更新它的内容。

js文件每年只更新几次,如果你不需要任何新的跟踪功能,就手动更新它。

https://developers.google.com/analytics/devguides/collection/analyticsjs/changelog

对于Nginx:

location ~ /analytics.js {
        proxy_pass https://www.google-analytics.com;
        expires 31536000s;
        proxy_set_header Pragma "public";
        proxy_set_header Cache-Control "max-age=31536000, public";
    }

将路径https://www.google-analytics.com/analytics.js修改为https://yoursite.com/analytics.js