Chrome.runtime.onMessage.addListener 在新标签页上没有从 popup.js 接收消息

Chrome.runtime.onMessage.addListener on new tab not receiving message from popup.js

本文关键字:popup js 消息 addListener onMessage runtime 新标签 标签 Chrome      更新时间:2023-09-26

我在弹出窗口中有以下代码.js它响应按钮按下以获取所有选项卡,创建一个新选项卡(模板.html),并将选项卡作为数组发送到新选项卡。稍后我将删除当前选项卡并在一个页面上显示链接以节省空间(这就是扩展的想法)。

function saveAll() {
  var openTabs = [];
  chrome.tabs.query({}, function(tabs) {
    for (var i = 0; i < tabs.length; i++) {
      openTabs[i] = tabs[i];
    }
    createSavedPage(openTabs);
  });
}
function createSavedPage(tabsToSave) {
  chrome.tabs.create({
      "url": chrome.extension.getURL("template.html"),
      "active": false
    },
    function(tab) {
      sendListToPage(tab, tabsToSave);
    }
  );
}

function sendListToPage(tab, tabsArray) {
  chrome.tabs.sendMessage(tab.id, {
    "action": "fill-list",
    "data": tabsArray
  });
}

var saveAllButton = document.getElementById("select-all-tabs");
saveAllButton.addEventListener("click", saveAll);

创建的选项卡包括模板.js文件:

function fillList(array) {
  var list = document.getElementById("link-list");
  for (var item in array) {
    //Something
  }
}
chrome.runtime.onMessage.addListener(
  function(request, sender, sendResponse) {
    if (request.action == "fill-list") {
      var data = request.data;
      fillList(data);
    }
  }
);

当我创建新选项卡时,消息是从扩展发送的,但从未收到。导致此问题的原因是什么?

我还认为消息是在创建的选项卡完全加载之前发送的。所以我通过添加一个chrome.tabs.on更新的侦听器来更改弹出窗口.js:

function createSavedPage(tabsToSave) {
  chrome.tabs.create({
      "url": chrome.extension.getURL("template.html"),
      "active": false
    },
    function(tab) {
      chrome.tabs.onUpdated.addListener(function(tabId, info)       {
        if (tabId == tab.id && info.status == "complete")
          sendListToPage(tab, tabsToSave);
      });
    }
  );
}

它似乎解决了这个问题。还有更好的方法吗?