Я знаю, что этот вопрос неоднократно задавали по-разному, но я попытался пройти все ответы (надеюсь, я никого не пропустил), и ни один из них не помог мне.
Вот код моего расширения:
манифест:
{
"name": "test",
"version": "1.1",
"background":
{
"scripts": ["contextMenus.js"]
},
"permissions": ["tabs", "<all_urls>", "contextMenus"],
"content_scripts" : [
{
"matches" : [ "http://*/*" ],
"js": ["jquery-1.8.3.js", "jquery-ui.js"],
"css": [ "jquery-ui.css" ],
"js": ["openDialog.js"]
}
],
"manifest_version": 2
}
contextMenus.js
function onClickHandler(info, tab) {
if (info.menuItemId == "line1"){
alert("You have selected: " + info.selectionText);
chrome.extension.sendMessage({action:'open_dialog_box'}, function(){});
alert("Req sent?");
}
}
chrome.contextMenus.onClicked.addListener(onClickHandler);
chrome.runtime.onInstalled.addListener(function() {
chrome.contextMenus.create({"id": "line1", "type": "normal", "title": "I'm line 1", "contexts":["selection"]});
});
openDialog.js
chrome.extension.onMessage.addListener(function(msg, sender, sendResponse) {
if (msg.action == 'open_dialog_box') {
alert("Message recieved!");
}
});
Два предупреждения фоновой страницы работают, а одно из content_script - нет.
сообщение журнала консоли: Ошибка порта: не удалось установить соединение. Приемного конца не существует.
В чем моя вина?
chrome.tabs.sendMessage()
для отправки сообщений в сценарии содержимого, а неchrome.extension.sendMessage()
.Ответы:
На своей фоновой странице вы должны позвонить
chrome.tabs.query({active: true, currentWindow: true}, function(tabs){ chrome.tabs.sendMessage(tabs[0].id, {action: "open_dialog_box"}, function(response) {}); });
вместо того, чтобы использовать,
chrome.extension.sendMessage
как вы это делаете сейчас.chrome.tabs
Вариант посылает сообщения скриптов контента, в то время какchrome.extension
функция посылает сообщение всех других компонентов расширения.источник
chrome.tabs.sendMessage
необходимо указать, на какую вкладку отправлять его . Итак, решение проблемы:chrome.tabs.query({active: true}, function(tabs){ chrome.tabs.sendMessage(tab.id, {action: "open_dialog_box"}, function(response) { }); });
chrome.runtime.onMessage.addListener( (message, sender, sendResponse) => { /* Code Here */ } );
message
- это параметр, содержащий{ action: "open_dialog_box" }
или все, что вы отправляете.sender
- это объект, содержащий идентификатор вашего расширения Chrome.sendResponse
- это параметр, содержащийfunction(response) {}
или любую переданную вами функцию, которая будет вызываться после обработки сообщения.@apsillers правильно. Также не забудьте вернуть true в слушателе сценария содержимого, иначе он может закрываться слишком рано.
chrome.runtime.onMessage.addListener((message, sender, sendResponse) => { console.log(message) return true });
источник