相信很多做网站的朋友网站有了一部分流量后就会挂上 Google AdSense 谷歌广告以维持服务器的运营需要,但是国内对于谷歌的网络优化并不是很好,很多网站在挂上Google AdSense 谷歌广告后网站的加载速度受影响,本来网站打开速度很快的,结果放上谷歌Google AdSense广告后,每次打开都要转圈圈,等谷歌Google AdSense广告全部显示出来后才算全部加载完成。这样给访客始终不太好的浏览体验。
1、Google AdSense 代码精简
首先我们需要精简优化 Google AdSense 谷歌广告的JS代码,我们申请 Google AdSense 广告的时候每创建一个广告位都会是以下这样:
<script async src=“https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js”></script>
<ins class=“adsbygoogle”
style=“display:block”
data-ad-client=“ca-pub-id”
data-ad-slot=“id”
data-ad-format=“auto”
data-full-width-responsive=“true”></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
那么我在网站的多个页面或一个页面投放多个Google AdSense 广告,这样就会造成打开一个网页重复加载多个js,那么一个页面里面有很多个这样的代码。你就会发现,其中每次都要调用一个
https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js
其实这个js只要调用一次就行了的。
问:如果我的网页上有多个广告单元,我是否要为每个广告单元添加
<script async src=”//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js”></script>
答:不需要,adsbygoogle.js
可以一次性加载完成。
以上是官方的回答,那么我们可以直接把以下这段js文件直接写入主题 head 里,相当于每页都会加载这个JS,就不会重复请求加载这个JS了,节省了多次调用adsbygoogle.js
的时间。
<script async src=“https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js”></script>
然后剩下的就精简为下面这样:
<ins class=“adsbygoogle”
style=“display:block”
data-ad-client=“ca-pub-id”
data-ad-slot=“id”
data-ad-format=“auto”
data-full-width-responsive=“true”></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
2、谷歌广告js延迟加载
有没有方法先让网页先展示,然后才到谷歌Google AdSense广告显示,而不影响网站打开的速度呢,用懒加载的方式加载 adsbygoogle.js 核心文件,建议将下列代码部署至