尽管我实际上找不到有效的解决方案,但我在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);
}
});
难道我做错了什么?
删除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会尝试显示弹出窗口,并且不会将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"]
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句