首页
/ uBlock Origin规则语法完全指南:编写高效广告拦截规则

uBlock Origin规则语法完全指南:编写高效广告拦截规则

2026-02-05 04:22:11作者:虞亚竹Luna

uBlock Origin(uBO)作为一款高效的宽频内容阻止程序,其强大之处在于灵活的规则系统。本文将系统讲解uBO规则语法,帮助你编写精准高效的广告拦截规则,让网页浏览更清爽。

规则基础与分类

uBO规则主要分为网络过滤规则和** cosmetic 过滤规则**两大类。网络过滤规则用于阻止网络请求,cosmetic 过滤规则用于隐藏页面元素,两者配合使用可实现全方位拦截。

网络过滤规则

网络过滤规则是uBO的核心,通过匹配URL模式来阻止广告、追踪器等资源加载。其基本结构包含模式选项两部分,格式为:模式$选项

常见的网络过滤规则类型有:

  • 主机名锚定规则||example.com^||表示匹配域名起始位置,^表示路径分隔符或结束符,可精准匹配example.com域名下的所有资源。
  • 例外规则@@||example.com^,以@@开头,表示允许该请求通过,常用于排除误拦截的正常资源。
  • 类型限制规则||example.com^$script$script指定仅阻止脚本类型资源,其他类型如imagestylesheet等也可按需使用。

cosmetic 过滤规则

cosmetic 过滤规则用于隐藏网页中的特定元素,如广告横幅、弹窗等,格式为域名##选择器。若省略域名,则对所有网站生效。

常见的 cosmetic 过滤规则类型:

  • 通用隐藏规则##.ad-banner,隐藏所有网站中class为ad-banner的元素。
  • 域名特定规则example.com##div[class^="promo"],仅隐藏example.com网站中class以promo开头的div元素。
  • 元素移除规则example.com###popup,移除example.com网站中id为popup的元素。

uBlock Origin 图标

网络过滤规则详解

基本模式语法

uBO网络过滤规则的模式部分支持多种特殊字符,用于精确匹配URL:

字符 作用 示例 匹配URL
* 匹配任意字符(包括空) *banner* https://example.com/banner.jpghttps://example.com/ads/banner
^ 匹配路径分隔符或URL结束 `
` ` 匹配域名起始位置
` ` 匹配URL起始或结束 `
/ 匹配路径分隔符 /ads/ https://example.com/ads/banner.jpg

选项参数

选项参数用于进一步限制规则的作用范围,多个选项用逗号分隔,如$script,third-party。常用选项:

  • 资源类型script(脚本)、image(图片)、stylesheet(样式表)、xmlhttprequest(XHR请求)等。
  • 第三方标记third-party(仅匹配第三方请求)、first-party(仅匹配第一方请求)。
  • 域名限制domain=example.com(仅对example.com生效)、domain=~example.com(对除example.com外的域名生效)。
  • 重定向redirect=noop.js(将请求重定向到内置的空脚本),常用于替换广告资源。

示例:||example.com^$image,third-party,domain=~blog.example.com,表示阻止第三方在除blog.example.com外的所有子域名下加载的example.com图片资源。

cosmetic 过滤规则详解

CSS选择器应用

cosmetic 过滤规则使用CSS选择器定位元素,支持常见的CSS选择器语法:

  • 类选择器.ad-class,匹配class为ad-class的元素。
  • ID选择器#ad-id,匹配id为ad-id的元素。
  • 属性选择器[name="ad"],匹配name属性为ad的元素;[src*="ad"],匹配src属性包含ad的元素。
  • 子选择器div > .ad-child,匹配div下的直接子元素中class为ad-child的元素。

示例:example.com##div.ad-container > img[alt="广告"],隐藏example.com网站中class为ad-container的div下alt属性为“广告”的图片元素。

扩展语法

uBO对cosmetic 过滤规则进行了扩展,支持更强大的元素定位:

  • ** procedural 过滤器**:##+js(noeval.js),执行内置脚本noeval.js阻止页面中的eval函数,需在设置中开启“允许通用 procedural 过滤器”。
  • 元素属性修改##[class="ad"]:style(display: none !important;),强制设置元素样式为隐藏。
  • 动态内容匹配##:has(> img[src*="ad"]),匹配包含子元素图片src含ad的元素。

高级规则技巧

规则优先级与例外处理

uBO规则遵循** specificity 原则例外优先**原则:

  • 更具体的规则优先级更高,如example.com##.ad优先于##.ad
  • 例外规则(@@开头)优先级最高,可覆盖普通规则。

示例:@@||example.com^$script,domain=example.com,允许example.com加载自身的脚本资源,即使存在阻止example.com脚本的通用规则。

性能优化

编写规则时需注意性能,避免过度复杂的规则导致页面加载缓慢:

  • 优先使用主机名锚定规则||example.com^),匹配效率高于通配符规则。
  • 限制通用 cosmetic 规则的作用域,避免使用##*等匹配范围过大的选择器。
  • 合并相似规则,如将example.com##.ad1example.com##.ad2合并为example.com##.ad1,.ad2

规则示例与实践

常见场景规则

  1. 阻止所有第三方广告图片

    ||*$image,third-party,domain=~*.png,~*.jpg
    

    该规则阻止所有第三方图片请求,但排除.png.jpg格式(可根据需要调整)。

  2. 隐藏视频网站前贴片广告

    video-site.com##.video-ad-container
    video-site.com##+js(abort-on-property-read.js, adPlay)
    

    第一条规则隐藏广告容器,第二条规则通过脚本阻止广告播放函数。

  3. 允许特定网站的广告

    @@||example.com^$domain=trusted-site.com
    

    trusted-site.com上允许example.com的所有请求,实现对可信网站的广告白名单。

规则测试与调试

uBO提供了便捷的规则测试工具:

  • 元素选择器:点击uBO图标→“选取元素并隐藏”,可直观选取页面元素生成cosmetic 规则。
  • 日志功能:在设置中开启“高级用户模式”,通过“记录器”查看网络请求和规则匹配情况,辅助调试规则。

uBO 记录器界面

总结与扩展

掌握uBO规则语法是提升广告拦截效率的关键。通过合理组合网络过滤和cosmetic 过滤规则,可有效拦截各类广告和追踪器。建议定期更新过滤列表,并根据个人需求编写自定义规则。

uBO还支持动态过滤规则订阅等高级功能,可进一步扩展拦截能力。动态过滤允许在不同网站上临时切换拦截策略,规则订阅则可获取社区维护的优质规则列表,如EasyList、EasyPrivacy等。

通过不断实践和优化规则,你将拥有一个干净、高效的网页浏览环境。

登录后查看全文
热门项目推荐
相关项目推荐