10

我想将任何网页上的文本(使用内容脚本处理选择)记录到作为弹出窗口资源的数据库中,以便在一个地方收集文本。

我正在尝试什么我在弹出页面中创建一个数据库并尝试从内容脚本管理它,尽管弹出窗口不活动(未打开)通过使用 chrome 消息传递但不能使弹出窗口接收来自内容脚本的任何消息。

我不确定使用消息传递来解决这个问题。有没有更好的解决方案?

4

1 回答 1

26

内容脚本无法将消息发送到不可见的弹出窗口,因为弹出窗口的上下文在隐藏时处于非活动状态(关闭)。

您的问题有几种解决方案。

选项 1:不传递消息,使用存储事件

如果您的“数据库”实际上是一个简单的键值存储,请切换到chrome.storageAPI。此 API 可用于内容脚本弹出窗口,并附带一个事件来通知您值更改。

例子:

// Get notified of changes (in the popup?)
chrome.storage.onChanged.addListener(function(changes, areaName) {
    // Do whatever you want with the changes.
});
// Initialization of the popup (print initial information?)
chrome.storage.local.get({keyName: 'defaultValue'}, function(items) {
    // Do something with items.keyName
});

// Content script, storage (remember document title?)
chrome.storage.local.set({keyName: document.title});

选项 2:将消息传递到后台/事件页面

弹出窗口和后台/事件页面共享相同的过程。与弹出窗口相关的任何数据库也可用于后台页面,反之亦然。此方法的高级概述:

  1. 内容脚本向后台页面发送消息。
  2. 后台页面将值存入数据库
  3. 如果弹出窗口已打开,请更新弹出窗口的视图。
  4. 如果弹出窗口被打开(所以它之前被关闭),它应该读取数据库(直接,或者通过使用从后台页面读取数据chrome.runtime.getBackgroundPage)并处理结果。

我在此答案中提供了与此流程对应的代码。

于 2013-06-14T12:48:14.780 回答