background.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // background.js
  2. chrome.runtime.onInstalled.addListener(function () {
  3. console.log("插件已被安装");
  4. });
  5. let rinfo = {}
  6. chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
  7. if (request.action === "show_popup") {
  8. const info = request.data;
  9. let n = chrome.windows.create({
  10. url: chrome.runtime.getURL("page.html"), // 指向你的弹出页面
  11. }, (newTab) => {
  12. rinfo[newTab.tabs[0].id] = info
  13. });
  14. }
  15. });
  16. // 监听已更新的标签,以找出何时打开了 page.html
  17. chrome.tabs.onUpdated.addListener((tabId, changeInfo, tab) => {
  18. if (changeInfo.status === 'complete' && tab.url.includes('page.html')) {
  19. chrome.tabs.sendMessage(tabId, { msgToPopup: rinfo[tabId] + new Date().toString() });
  20. }
  21. });
  22. // // background.js
  23. // chrome.runtime.onInstalled.addListener(function () {
  24. // console.log("插件已被安装");
  25. // });
  26. // let jsRequests = [];
  27. // let jsRequestsByTab = {}; // 用于存储每个标签页的请求
  28. // chrome.webRequest.onBeforeRequest.addListener(
  29. // (details) => {
  30. // const tabId = details.tabId; // 获取当前请求的标签页 ID
  31. // const url = details.url;
  32. // let uri = new URL(url);
  33. // if (
  34. // details.initiator &&
  35. // uri.pathname.endsWith(".js") &&
  36. // (uri.protocol.startsWith("http") || uri.protocol.startsWith("https"))
  37. // ) {
  38. // // 确保有个数组来记录当前标签页的请求
  39. // if (!jsRequestsByTab[tabId]) {
  40. // jsRequestsByTab[tabId] = [];
  41. // }
  42. // jsRequestsByTab[tabId].push(url);
  43. // }
  44. // },
  45. // { urls: ["<all_urls>"] }
  46. // );
  47. // chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
  48. // if (request.action === "getJsRequests") {
  49. // const tabId = sender.tab.id; // 获取请求来源的标签页 ID
  50. // sendResponse(jsRequestsByTab[tabId] || []);
  51. // }
  52. // });
  53. // // 监听标签页更新(包括刷新)事件以清空请求记录
  54. // chrome.tabs.onUpdated.addListener((tabId, changeInfo, tab) => {
  55. // if (changeInfo.status === "loading") {
  56. // // 标签页加载完成时清空请求记录
  57. // delete jsRequestsByTab[tabId];
  58. // }
  59. // });
  60. // // 监听标签页关闭事件以清空请求记录
  61. // chrome.tabs.onRemoved.addListener((tabId) => {
  62. // delete jsRequestsByTab[tabId]; // 清空对应标签页的请求记录
  63. // });