javascript - 努力在 Chrome 扩展中获取 DOM 数据

标签 javascript google-chrome-extension

我在 Stack Overflow 上发现了几个投票率很高的问题,尽管我实际上找不到可行的解决方案。

我一直在尝试遵循这里的答案:Chrome Extension - Get DOM content , 但我仍然得到一个完全空白的控制台(尽管重新加载扩展)!

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);
    }
});

我做错了什么吗?

最佳答案

删除 default_popup来自browser_action :
问题是您正在定义 default_popup对于browser_action在您的 manifest.json 中。更改browser_action至:

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

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

仅注入(inject)https方案页面:
鉴于您仅将内容脚本注入(inject) https://页面,请确保您正在使用 https 的页面上进行测试方案。

您可能会发现通过将内容脚本注入(inject)所有 URL 可以更轻松地进行测试。您可以通过更改 content_script 来做到这一点将您的 manifest.json 键入:

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

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

加载扩展程序后必须加载内容页面:
您还需要确保在加载或重新加载扩展程序后已重新加载页面、打开新选项卡或导航到新页面。您的内容脚本不会注入(inject)到已加载的页面中。

输出位于后台页面的控制台中:
此外,您还需要查看 console for your background page 。您可能需要查看多个控制台,具体取决于您调用的上下文/范围 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"]
}

关于javascript - 努力在 Chrome 扩展中获取 DOM 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40668595/

相关文章:

javascript - 如何返回嵌套的 promise ?

Javascript 函数只调用了一半的时间

javascript - Firefox 不会在@font-face 中声明的跨浏览器请求中发送 cookie

javascript - Chrome 扩展 : Programmatically setting browser action icon causes the icon to pixelate

javascript - 未捕获的类型错误 : Cannot read property '0' of null in Chrome extension

javascript - Protractor 与 frisby API 集成

javascript - Slick Carousel + Accordion 格式问题

javascript - 如何使用 chrome 扩展程序影响网站

javascript - Chrome 扩展 : Not allowed to load local resource

google-chrome-extension - "Error: Missing host permission for the tab"在 View 源 : URLs