繁体   English   中英

努力在Chrome扩展程序中获取DOM数据

[英]Struggling to get DOM data in Chrome extension

尽管我实际上找不到可行的解决方案,但我在Stack Overflow上找到了几个非常有争议的问题。

我一直在尝试遵循以下答案: Chrome扩展程序-获取DOM内容 ,但我仍然得到一个完全空白的控制台(尽管重新加载了扩展程序)!

manifest.json

{
  "manifest_version": 2,
  "name": "Test Extension",
  "version": "0.0",
  "background": {
    "persistent": false,
    "scripts": ["background.js"]
  },
  "content_scripts": [{
    "matches": ["https://*/*"],
    "js": ["content.js"]
  }],
  "browser_action": {
    "default_title": "Test Extension",
    "default_icon": "icon.png",
    "default_popup": "popup.html"
  },

  "permissions": ["activeTab"]
}

background.js

// A function to use as callback
function logDOM(domContent) {
    console.log('I received the following DOM content:\n' + domContent);
}

// When the browser-action button is clicked...
chrome.browserAction.onClicked.addListener(function (tab) {
    console.log(tab.url);
    chrome.tabs.sendMessage(tab.id, {text: 'report_back'}, logDOM);

});

content.js

// Listen for messages
chrome.runtime.onMessage.addListener(function (msg, sender, sendResponse) {
    // If the received message has the expected format...
    if (msg.text === 'report_back') {
        // Call the specified callback, passing
        // the web-page's DOM content as argument
        sendResponse(document.all[0].outerHTML);
    }
});

难道我做错了什么?

browser_action删除default_popup
问题是您在manifest.json中browser_action定义了default_popup browser_action更改为:

"browser_action": {
  "default_title": "Test Extension",
  "default_icon": "icon.png"
},

如果您定义default_popup ,则Chrome会尝试显示弹出窗口,并且不会将click事件发送到您的后台脚本。 您应该已经看到一个弹出窗口,显示未找到您的文件。

仅注入https方案页面:
假设您仅将内容脚本注入到https://页面中,请确保您正在使用https方案的页面上进行测试。

通过将内容脚本注入所有URL,您可能会发现测试起来更容易。 您可以通过将manifest.json中content_script键更改为:

"content_scripts": [{
  "matches": ["<all_urls>"],
  "js": ["content.js"]
}],

它也不会注入chrome方案的页面中(例如chrome://extensions/ )(即使使用<all_urls> )。 因此,您的扩展程序将无法在这些页面上运行。

您必须在加载扩展名后加载内容页面:
您还需要确保在加载或重新加载扩展程序后已重新加载页面,打开新标签或导航到新页面。 您的内容脚本未注入到已加载的页面中。

输出在您的背景页面的控制台中:
此外,您需要查看控制台的背景页面 根据要在哪个上下文/范围中调用console.log() ,您可能需要查看多个控制台。 本节第一句中链接的答案描述了如何查看它们。

manifest.json,其中包含所有提及的更改:

{
  "manifest_version": 2,
  "name": "Test Extension",
  "version": "0.0",
  "background": {
    "persistent": false,
    "scripts": ["background.js"]
  },
  "content_scripts": [{
    "matches": ["<all_urls>"],
    "js": ["content.js"]
  }],
  "browser_action": {
    "default_title": "Test Extension",
    "default_icon": "icon.png"
  },

  "permissions": ["activeTab"]
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM