首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Chrome扩展中难以获取DOM数据

在Chrome扩展中难以获取DOM数据
EN

Stack Overflow用户
提问于 2016-11-18 02:50:46
回答 1查看 470关注 0票数 0

我已经在Stack溢出上找到了几个很有投票权的问题,尽管我实际上找不到一个可行的解决方案。

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

manifest.json

代码语言:javascript
复制
{
  "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

代码语言:javascript
复制
// 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

代码语言:javascript
复制
// 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);
    }
});

我做错了什么吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-18 04:56:00

default_popup browser_action中删除

问题在于您正在为您的default_popup中的browser_action定义一个manifest.json。将browser_action更改为:

代码语言:javascript
复制
"browser_action": {
  "default_title": "Test Extension",
  "default_icon": "icon.png"
},

如果您定义了一个default_popup,那么Chrome将尝试显示弹出窗口,而不会向您的后台脚本发送单击事件。您应该看到一个弹出窗口显示,您的文件没有找到。

只向https 方案页注入:

考虑到您只是将内容脚本注入https://页面,请确保在使用https方案的页面上进行测试。

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

代码语言:javascript
复制
"content_scripts": [{
  "matches": ["<all_urls>"],
  "js": ["content.js"]
}],

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

必须在加载扩展名:之后加载内容页

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

输出在后台页面的控制台中:

此外,您还需要查看console for your background page。根据调用console.log()的上下文/作用域,可能需要查看多个控制台。本节第一句中链接的答案描述了如何查看它们。

具有所有提到的更改的manifest.json

代码语言:javascript
复制
{
  "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"]
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40668595

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档