Chrome 扩展程序可在显示文本之前替换网页和 Facebook 帖子中的文本

2023-12-05

我正在开发一个 Chrome 扩展程序,它可以替换网页文本中的指定字符串或正则表达式。

总体来说效果很好,但有两个问题我想解决:

(1) 在文本替换发生之前,显示原始的、未更改的网页文本。

(2) 文本替换不会影响滚动到页面底部后动态加载的 Facebook 帖子。

这是代码,改编自https://stackoverflow.com/a/6012345#6012345有微小的变化。

// manifest.json

{
    "manifest_version": 2,
    "name": "Replace Text",
    "version": "1.0", 

    "content_scripts": [ {
        "js": [ "jquery.min.js", "replace.js" ],
        "matches": [ "<all_urls>" ],
        "run_at": "document_end"
    } ]
}


// replace.js

jQuery.fn.textWalk = function( fn ) {
    this.contents().each( jwalk );

    function jwalk() {
        var nn = this.nodeName.toLowerCase();
        if( nn === '#text') {
            fn.call( this );
        } else if( this.nodeType === 1 && this.childNodes && this.childNodes[0] && nn !== 'script' && nn !== 'textarea' ) {
            $(this).contents().each( jwalk );
        }
    }
    return this;
};

$('body').textWalk(function() {
    this.data = this.data.replace('This Text', 'That Text');
    this.data = this.data.replace(/[Rr]eplace\s[Ss]ome\s[Tt]ext/g, 'with other text');  
});

我在网上找到了一些部分答案,但无法让它们正常工作。

例如,提出的一种解决方案是更改"run_at": "document_end" to "run_at": "document_start"。这会在构建 DOM 之前运行内容脚本,因此理论上它应该在显示任何内容之前进行文本替换。但就我而言,它导致扩展完全停止替换文本。


一个可行的替代方案是通过以下方式监听 DOM 更改:变异观察者并动态更改 TextNodes(或其他内容)的内容。从技术上讲,这不会发生before正在渲染任何内容,但它应该足够接近,让用户不会注意到(除非您所做的更改很大)。

另请参阅我对一个问题的回答类似的问题.

示例代码

(这仍然需要twicking,例如处理动态节点更新。)

内容.js:

// Modify the content somehow...
var doFilter = function(textNode) {
    textNode.data = textNode.data + "<br />" + textNode.data;
}

// Create a MutationObserver to handle events
// (e.g. filtering TextNode elements)
var observer = new MutationObserver(function(mutations) {
    mutations.forEach(function(mutation) {
        if (mutation.addedNodes) {
            [].slice.call(mutation.addedNodes).forEach(function(node) {
                if (node.nodeName.toLowerCase() == "#text") {
                    doFilter(node);
                }
            });
        }
    });
});

// Start observing "childList" events in document and its descendants
observer.observe(document, {
    childList: true,
    subtree:   true
});

(上面的代码用于监听添加的节点。您可能希望有一个观察者监听characterData and childList主体及其后代的变化以“捕获”动态加载/更改的内容。)

清单.json:

...
"content_scripts": [
    {
        "matches": [...],
        "js":         ["content.js"],
        "run_at":     "document_start",
        "all_frames": true
    }
],
...

如果您决定去变异观察者方法,这个 JS 库应该会让你的生活更轻松:突变总结


关于您的问题,为什么在“document_start”执行脚本没有任何效果:
发生这种情况是因为当时(“document_start”)您的脚本没有任何内容可以替换(即在将任何其他内容添加到 DOM 之前加载并运行它)。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Chrome 扩展程序可在显示文本之前替换网页和 Facebook 帖子中的文本 的相关文章

随机推荐

  • React Native 中的 CameraX 视图 - 无法配置相机

    我正在创建cameraX视图 以便通过桥接来反应本机 普通视图在RN中渲染 桥接流程很好 PreviewView用于显示 CameraX 预览的相机源 我已成功实现预览 但不确定为什么预览未在 UI 上呈现 它只是一个空白屏幕 让我知道 U
  • Django 使用相关实体字段序列化查询集

    我正在尝试加入 2 个实体 从中获取特定字段 然后返回该实体的 JSON 我尝试编写以下代码 import datetime result Foo objects all result result select related bar e
  • 有没有“单项大小的异步任务缓冲区”这样的同步工具?

    在 UI 开发中 我多次以这样的方式处理事件 当事件第一次出现时 我立即开始处理 但如果有一个处理操作正在进行中 我会等待它完成 然后再处理另一个事件 如果在操作完成之前发生多个事件 我只处理最近的一个 我通常的做法是 我的处理方法有一个循
  • 如何允许 Java 客户端 TLS10 连接?

    在尝试使用 Java 16 在 Eclipse 中执行 hello world MSSQL JDBC 连接时 出现以下错误 server selected protocol version TLS10 is not accepted by
  • 如何将mongodb文档中的所有数组元素更改为某个值? [复制]

    这个问题在这里已经有答案了 假设我有以下文档 id ObjectId 5234cc89687ea597eabee675 code xyz tags school book bag headphone appliance qty size S
  • 从aspx网页读取xml

    我们必须从 aspx 页面读取数据 当我们使用查询字符串调用页面时 它会返回一个 xml 文档 其中包含与查询字符串匹配的数据 我们有一个与我们返回的 xml 相匹配的 XSD 我想我们可以从http响应中读取xml文档 这行得通吗 我们怎
  • 从服务访问 UI 线程处理程序

    我正在 Android 上尝试一些新的东西 我需要访问 UI 线程的处理程序 我知道以下几点 UI线程有自己的处理程序 和活套 任何消息都会被放置 进入UI的消息队列 线 Looper 获取事件 并将其传递给处理程序 处理程序处理消息并 将
  • 确保 MATLAB 不会重新计算符号表达式

    我正在构建 我的第一个 MatLab 程序 它需要对方程进行符号微分 然后多次使用此解决方案 使用不同的数字输入 我不希望它每次需要输入一组新的数值时都重新计算符号微分 这可能会大大增加运行该程序所需的时间 鉴于其本质 数字优化器 这可能已
  • MPDF 电子邮件附件发送空白 PDF

    我已经使用 mpdf 成功生成了 PDF 我已通过下载 PDF 进行了验证 但是 当我将 PDF 作为电子邮件附件发送时 我收到 Adob e Reader 的空白 PDF 并显示 内存不足 错误 下面是我的代码
  • 为什么 dart 错误地推断出我的泛型参数类型?

    当我明确地将 mySet 变量等同于 int 集文字时 我似乎无法理解为什么 mySet 变量被推断为具有动态参数类型的通用集 那么这个结果合乎逻辑吗 还是 dart 确实未能推断出泛型集参数类型 main Set mySet 1 2 3
  • Xamarin + Android + 绑定 YouTube 视频播放器编译错误

    我希望将 YouTubeAndroidPlayerApi jar 绑定到我的 Xamarin Android 项目中 我已在 Jars 文件夹下添加了 YouTubeAndroidPlayerApi jar 但我的项目无法编译 错误 不要覆
  • 仅通过意图共享到 LinkedIn 的类名称

    我目前正在 Android 应用程序中为精选的流行平台创建直接意图以共享一些文本 我目前正在尝试获得与 LinkedIn 合作的直接意向 我目前有一个为 Twitter 工作的直接意图 如下所示 shareIntent new Intent
  • 在 Eclipse 中运行单个 JUnit 测试

    如果我有一个包含多个测试的测试套件 当我尝试从代码编辑器的上下文菜单或 JUnit 视图运行单个单元测试时 它似乎坚持始终运行整个套件 而不是单次测试 有没有办法禁用更改此行为 以便我可以要求运行该测试 并且仅运行该测试 在包资源管理器中展
  • 我无法让这个 mysql join 查询产生所需的结果

    三个表的结构 Booking CREATE TABLE booking bookingID int 11 NOT NULL AUTO INCREMENT receipt no int 11 NOT NULL client varchar 3
  • 无法隐式初始化 std::function

    我编写了这个函子来执行and手术 unary functor performs template
  • 将只读docker卷的变化反映到容器中?

    我有一个配置文件在运行时使用只读卷注入到 Docker 中 因此容器无法更改配置文件的内容 但主机可以 这个想法是向容器内的进程发送 SIGHUB 以重新加载任何配置更改 然而 Docker 似乎无法检测到配置文件的任何更改 并且似乎看到了
  • 工具栏在 RecyclerView 滚动条上留下空白并隐藏

    我试图在 RecyclerView 滚动条上隐藏我的工具栏 到目前为止它似乎已经隐藏了 但它留下了一个白色的空白 我很确定这与我的 MainActivity 布局和 FrameLayout 中的片段的叠加有关 这是我的activity ma
  • @OneToMany List<> 与 Set<> 区别

    如果我使用的话有什么区别吗 OneToMany public Set
  • 在 OS X 上保留内存

    相当于 Windows 的是什么VirtualAlloc在 OS X 中 也就是说 我如何保留一个连续的地址空间而不实际提交它 然后稍后提交它的块 Thanks Alex The mmap 函数 调用MAP ANON MAP PRIVATE
  • Chrome 扩展程序可在显示文本之前替换网页和 Facebook 帖子中的文本

    我正在开发一个 Chrome 扩展程序 它可以替换网页文本中的指定字符串或正则表达式 总体来说效果很好 但有两个问题我想解决 1 在文本替换发生之前 显示原始的 未更改的网页文本 2 文本替换不会影响滚动到页面底部后动态加载的 Facebo