adsense广告不出现的处理方式

adsense广告在广告展示失败的时候,需要采取一些措施来保证页面不会出现空白区域等现象,最早是使用了替补游戏来弥补广告不能正常展示。本次处理需要去除这些替补游戏的展示,广告不成功展示或者不展示,直接隐藏处理,来达到不影响其他进行的业务。

背景

当广告单元完成对广告的请求后,AdSense 会向 <ins> 元素添加一个名为 data-ad-status 的参数。 根据系统是否返回广告,此参数将更新为以下项之一:

data-ad-status="filled" 系统向广告单元返回了一个广告,该广告正在展示。
data-ad-status="unfilled" 系统未返回任何广告,广告单元为空。

处理方式

  • 1、直接使用CSS 隐藏广告空缺的广告单元ins元素
css 复制代码
ins.adsbygoogle[data-ad-status="unfilled"] {  
    display: none !important;  
}
  • 2、仅在广告单元出现广告空缺时展示替补广告
javascript 复制代码
<ins class="adsbygoogle"  
     style="display:inline-block;width:300px;height:250px"  
     data-ad-client="ca-pub-1234567890123456"  
     data-ad-slot="1234567890">  
    <a href="/page"><img src="/backup.jpg" width="300px" height="250px"></a>  
</ins>
<style>
    ins.adsbygoogle a {  
        display: none !important;  
    }  
    ins.adsbygoogle[data-ad-status="unfilled"] a {  
        display: block;  
    }
</style>
  • 3、可以使用 MutationObserver 检测 data-ad-status 参数发生的更改,来隐藏样式
  • 4、当页面不满足添加adsense广告时,但是页面里已经提起占据了一个位置这时候需要隐藏这个占位,等满足其他条件需要添加广告时候才保留,可以使用:empty来处理这种场景(id:#xxxx-ad 元素是没有子元素的)
css 复制代码
#xxxx-ad:empty {
    display: none !important;
}
  • 5、当在第四种场景下,同时里面展示了广告,但是广告展示不成功的话,需要使用:has来处里这种场景
xml 复制代码
<div class="card" id="xxxx-ad">
    <ins class="adsbygoogle"  data-ad-status="unfilled">
    ...
    </ins>
</div>
<style>
      #xxxx-ad:has(ins.adsbygoogle[data-ad-status="unfilled"]) {
        display:none;     
      } 
</style>

参考

相关推荐
i小溪29 分钟前
Easy (Horizontal Scrollbar) Fixes for Your Blog CSS 博客 CSS 的简易(水平滚动条)修复
css
donecoding3 小时前
Sass 模块化革命:告别 @import,拥抱 @use 和 @forward
前端·css·代码规范
迦南giser5 小时前
webpack从0到1详解
前端·javascript·css·webpack·node.js
冴羽6 小时前
现代 CSS 颜色使用指南
前端·javascript·css
float_六七7 小时前
CSS行内盒子:30字掌握核心特性
前端·css
donecoding7 小时前
CSS的"双胞胎"陷阱:那些看似对称却暗藏玄机的属性对
前端·css·代码规范
未来之窗软件服务8 小时前
幽冥大陆(九十九)文件大小换算+软考—东方仙盟练气期
css·html·css3·计算机软考·仙盟创梦ide·东方仙盟
thinkQuadratic9 小时前
CSS给文本添加背景颜色等效果
前端·css
C_心欲无痕9 小时前
前端网站主题切换原理与实践:CSS 类名切换方案
前端·css
Jing_Rainbow1 天前
【 前端三剑客-39 /Lesson65(2025-12-12)】从基础几何图形到方向符号的演进与应用📐➡️🪜➡️🥧➡️⭕➡️🛞➡️🧭
前端·css·html