У мене є хромоване розширення. мені потрібно проаналізувати з джерела HTML поточної сторінки. Я знайшов тут всілякі рішення з фоновими сторінками та сценаріями вмісту, але жодне мені не допомогло. ось що я маю на даний момент:
manifest.json:
{
"name": "Extension",
"version": "1.0",
"description": "Extension",
"browser_action": {
"default_icon": "bmarkred.ico",
"popup": "Test.html"
},
"content_scripts": [
{
"matches": ["http://*/*"],
"js": ["content.js"]
}
],
"background": {
"page": "backgroundPage.html"
},
"permissions": [
"cookies",
"tabs",
"http://*/*",
"https://*/*"
]
}
background.html:
<html>
<head>
<script type="text/javascript">
try {
chrome.tabs.getSelected(null, function (tab) {
chrome.tabs.sendRequest(tab.id, {action: "getSource"}, function(source) {
alert(source);
});
});
}
catch (ex) {
alert(ex);
}
</script>
</head>
</html>
content.js:
chrome.extension.onRequest.addListener(function(request, sender, callback) {
if (request.action == "getSource") {
callback(document.getElementsByTagName('html')[0].innerHTML);
}
});
Оповіщення завжди попереджає невизначеним. навіть якщо я змінив у файлі content.js функцію зворотного виклику на:
callback('hello');
все той же результат. Що я роблю не так? можливо, я йду в цьому неправильним шляхом. що мені справді потрібно це. Коли користувач відкриває спливаюче вікно розширення (і лише тоді), мені потрібен HTML поточної сторінки, щоб я міг його проаналізувати. будь-які пропозиції?