我希望你能帮助我。
我正在尝试在 Chrome 中创建一个扩展,它将活动选项卡的源加载到变量中。
到目前为止,我有:
清单.json
{
"name": "My Extension",
"manifest_version": 2,
"version": "0.1",
"description": "Does some simple stuff",
"browser_action": {
"default_icon": "logo.png"
},
"background": {
"scripts": ["main.js"]}}
main.js
chrome.browserAction.onClicked.addListener(
function(tab) {
var ps1 = document.getElementsByTagName('html')[0].innerHTML;
window.alert(ps1);
});
但这会加载空白页面的页面源。我需要做什么才能获取活动页面的来源。
我已经阅读了一些内容,我认为我需要使用带有一些听力功能的内容脚本,我一直在搜索,但在我看来所有答案都非常复杂。你们中的任何人都可以给我一些简单的例子吗?
非常感谢您的反馈!
问候
AdrianCooney 回答后更新:
我将清单更改为包含
"permissions": [
"tabs"
]
然后在 main.js 我做了
chrome.browserAction.onClicked.addListener(function(activeTab) {
chrome.tabs.query({ currentWindow: true, active: true },
function (tabs) {
var ps1=document.getElementsByTagName('html')[0].innerHTML;
window.alert(ps1);
})
});
当我按下扩展按钮时,我得到类似的东西
<html></html>
<body><script src="main.js"></script>
</body>
...无论我有什么标签。
再次尝试使用 chrome.tabs.getCurrent
chrome.browserAction.onClicked.addListener(function(activeTab) {
chrome.tabs.getCurrent(
function (tabs) {
var ps1=document.getElementsByTagName('html')[0].innerHTML;
window.alert(ps1);
})
});
上面版本的 main.js 提供与之前完全相同的输出,无论我有哪个页面处于活动状态。