Google の非同期分析トラッキング コードは次のとおりです。
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-XXXXX-Y']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
私に言わせれば、それはかなり醜いです。これは次のように要約できます (クレジット: Mathias ):
<script>
var _gaq=[['_setAccount','UA-XXXXX-X'],['_trackPageview']];
(function(d,t){var g=d.createElement(t),s=d.getElementsByTagName(t)[0];
g.src=('https:'==location.protocol?'//ssl':'//www')+'.google-analytics.com/ga.js';
s.parentNode.insertBefore(g,s)}(document,'script'));
</script>
async
しかし、HTML5属性とプロトコル相対 URL
だけを使用できないのはなぜでしょうか?
<script src="//www.google-analytics.com/ga.js" async></script>
<script>var _gaq=[['_setAccount','UA-XXXXX-X'],['_trackPageview']];</script>
プロトコル相対 URL を使用すると、 をチェックする必要がなくなりますlocation.protocol
。また、属性は、最新のブラウザasync
で目立たない読み込みを処理する必要があり、他のブラウザでは適切に劣化します。
これは良くないですか?