0

0

如何让 Chrome 扩展持久化记住用户按钮状态并自动执行过滤功能

花韻仙語

花韻仙語

发布时间:2026-03-08 22:00:31

|

990人浏览过

|

来源于php中文网

原创

如何让 Chrome 扩展持久化记住用户按钮状态并自动执行过滤功能

本文介绍如何使用 chrome.storage 持久化保存用户操作(如“omit”按钮开关状态),并在页面加载时自动恢复行为;同时提供基于 web api 的实时敏感词过滤集成方案,兼顾本地性能与云端更新能力。

本文介绍如何使用 chrome.storage 持久化保存用户操作(如“omit”按钮开关状态),并在页面加载时自动恢复行为;同时提供基于 web api 的实时敏感词过滤集成方案,兼顾本地性能与云端更新能力。

在开发内容过滤类 Chrome 扩展时,一个核心体验需求是:用户点击一次“Omit”按钮后,其偏好应跨页面刷新、跨会话长期生效,并自动作用于目标网页——而非每次重载都需重复操作。这要求扩展具备状态持久化上下文感知的自动执行能力。下面将从存储机制、自动触发逻辑和云端词库协同三方面给出可落地的实现方案。

✅ 优先使用 chrome.storage.local(推荐)

虽然 localStorage 在部分简单场景下可用,但 Chrome 扩展中必须使用 chrome.storage API 才能确保跨会话、跨标签页一致性,且支持同步/异步操作、配额更大(默认 5MB)、兼容服务工作线程(Service Worker)背景页。

以下是在 content script 中实现“Omit 开关记忆 + 自动过滤”的完整逻辑:

// content.js
async function toggleOmit() {
  const { omitEnabled = false } = await chrome.storage.local.get('omitEnabled');
  const newStatus = !omitEnabled;
  await chrome.storage.local.set({ omitEnabled: newStatus });
  if (newStatus) {
    filterInappropriateContent(); // 执行过滤函数
  }
}

// 页面加载时检查并自动应用
async function initOnLoad() {
  const { omitEnabled = false } = await chrome.storage.local.get('omitEnabled');
  if (omitEnabled) {
    filterInappropriateContent();
  }
}

// 绑定按钮事件(假设按钮 id="omit-btn")
document.addEventListener('DOMContentLoaded', () => {
  const omitBtn = document.getElementById('omit-btn');
  if (omitBtn) {
    omitBtn.addEventListener('click', toggleOmit);
  }
  initOnLoad(); // 立即检查是否需自动过滤
});

// 示例过滤函数(可替换为更健壮的 DOM 遍历或正则替换)
function filterInappropriateContent() {
  const badWords = ['damn', 'stupid', 'idiot']; // 实际应从远程 API 或 manifest 配置加载
  const walker = document.createTreeWalker(
    document.body,
    NodeFilter.SHOW_TEXT,
    null,
    false
  );
  let node;
  while ((node = walker.nextNode())) {
    let text = node.textContent;
    badWords.forEach(word => {
      const regex = new RegExp(`\b${word}\b`, 'gi');
      text = text.replace(regex, '[FILTERED]');
    });
    if (text !== node.textContent) {
      node.textContent = text;
    }
  }
}

⚠️ 注意事项:

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

下载
  • chrome.storage.local 是异步 API,不可在 document.write 或同步脚本早期直接调用;务必在 DOMContentLoaded 或 window.onload 后使用;
  • 若扩展采用 Manifest V3,content script 默认运行在独立世界(isolated world),无法直接访问页面 JS 变量,但可安全操作 DOM;
  • 避免在 chrome.storage 中存储大量原始文本(如整页 HTML),应只存布尔状态、配置 ID 或轻量元数据。

? 集成动态词库:通过 Messaging 调用后台服务

你提到希望“链接到持续更新的 Web 应用词库”,最佳实践是:由 background service worker 统一管理词库拉取与缓存,content script 仅通过 chrome.runtime.sendMessage 请求最新规则

示例流程如下:

  1. Background Service Worker(background.js)定时拉取词库
    // background.js
    let cachedWords = [];

async function fetchProfanityList() { try { const res = await fetch('https://www.php.cn/link/a0a7ffa593070c447c15f66e0aab9785', { headers: { 'X-Api-Key': 'YOUR_API_KEY' } }); // 注意:Ninjas API 实际不返回词表,此处仅为示意;建议自建词库接口返回 JSON 数组 const data = await res.json(); cachedWords = data.words || ['damn', 'heck']; // 替换为真实响应结构 await chrome.storage.local.set({ profanityWords: cachedWords }); } catch (e) { console.warn('Failed to fetch word list:', e); } }

// 启动时 + 每 6 小时更新一次 fetchProfanityList(); setInterval(fetchProfanityList, 6 60 60 * 1000);

// 响应 content script 查询 chrome.runtime.onMessage.addListener((request, sender, sendResponse) => { if (request.action === 'getWords') { sendResponse({ words: cachedWords }); } });

2. **Content Script 异步获取并应用最新词表**:
```javascript
// content.js 中增强 filterInappropriateContent()
async function getLatestBadWords() {
  return new Promise(resolve => {
    chrome.runtime.sendMessage({ action: 'getWords' }, response => {
      resolve(response?.words || []);
    });
  });
}

async function filterInappropriateContent() {
  const badWords = await getLatestBadWords();
  if (badWords.length === 0) return;

  const walker = document.createTreeWalker(/* ... */);
  // …… 同上 DOM 替换逻辑
}

? 总结与进阶建议

  • 状态持久化首选 chrome.storage.local,它比 localStorage 更可靠、更符合扩展安全模型;
  • 自动执行 = 页面加载钩子 + 存储状态检查,无需 pushState 或复杂路由监听;
  • 动态词库 = background 统一管理 + runtime messaging 解耦通信,避免每个 content script 重复请求;
  • ? 若涉及敏感词匹配,建议在后台完成正则编译或模糊匹配逻辑,再下发轻量规则,提升 content script 性能;
  • ? 对于高可用需求,可结合 chrome.alarms 实现离线 fallback 词表,或使用 chrome.storage.sync 同步用户偏好至其他设备(注意 100KB 配额限制)。

通过以上结构化设计,你的扩展不仅能“记住按钮”,更能成为智能、可演进、可运维的内容净化助手。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1050

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

830

2023.11.06

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

560

2023.09.20

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号