Bilibili-Evolved项目广告屏蔽功能的技术分析与优化
2025-05-07 10:04:53作者:尤峻淳Whitney
背景介绍
Bilibili-Evolved是一个针对B站网页端的用户脚本项目,主要功能包括界面美化、功能增强以及广告屏蔽等。近期用户反馈B站新增了一种右下角遮盖横幅广告,影响了用户体验。
技术分析
广告元素识别
根据用户提供的截图和HTML代码片段,可以分析出这种新型广告具有以下特征:
- 位于页面右下角固定位置
- 包含图片展示区域和关闭按钮
- 采用响应式设计,适配不同屏幕尺寸
- 使用CSS类名"palette-button-adcard"标识
广告加载机制
从代码结构来看,这类广告可能是通过B站的动态内容加载系统注入到页面中的。它们使用了现代Web技术:
- 图片采用多格式支持(avif/webp/fallback)
- 使用SVG矢量图标作为关闭按钮
- 采用CSS Flex布局实现响应式设计
解决方案
现有脚本的局限性
当前版本的Bilibili-Evolved(2.9.4)尚未包含对这种新型广告的屏蔽规则。这主要是因为:
- 广告是近期新增的,脚本还未及时适配
- 广告使用新的CSS类名,需要更新选择器
- 广告位置和行为模式与之前处理的类型不同
技术实现方案
要有效屏蔽这类广告,可以考虑以下技术方案:
- CSS选择器屏蔽:通过识别广告容器的特定类名,设置display:none属性
- DOM监听拦截:使用MutationObserver监听DOM变化,在广告元素插入时立即移除
- 请求拦截:分析广告资源的加载URL模式,在请求阶段就进行阻断
优化建议
对于脚本开发者,建议:
- 建立更完善的广告元素特征库,提高识别率
- 实现动态规则更新机制,无需等待脚本版本更新
- 考虑用户自定义规则功能,增强灵活性
对于普通用户,可以:
- 关注脚本的更新通知
- 在遇到新广告时及时反馈具体信息
- 临时使用浏览器插件辅助屏蔽
总结
Bilibili-Evolved项目通过持续的技术迭代,为用户提供更好的B站浏览体验。面对平台方不断变化的广告策略,需要开发者社区和用户的共同努力,才能保持高效的内容净化能力。这类项目也体现了开源社区在改善用户体验方面的重要价值。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0113
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
最新内容推荐
项目优选
收起
deepin linux kernel
C
32
16
暂无描述
Dockerfile
762
4.96 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.8 K
191
Ascend Extension for PyTorch
Python
718
873
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
856
1.91 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.07 K
1.09 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.73 K
1.02 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
676
1.32 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
455
438
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
C
454
5.07 K