从弹出脚本到内容脚本的 WebExtension 消息
WebExtension message from popup script to content script
我是 Firefox 扩展的新手。我试图在单击按钮时将消息从弹出脚本发送到内容脚本,但我收到此错误:
Could not establish connection. Receiving end does not exist.
我没有收到任何其他错误,所以我不确定为什么会出现此错误。
弹出脚本:
document.getElementById("rec").addEventListener("click", (e) => {
var query = browser.tabs.query({currentWindow: true, active : true});
var tab = query.then(getTab,onError);
function getTab(tabs) {
for (let tab of tabs){
send(tab.id);
}
}
function onError(error) {
console.log(`Error: ${error}`);
}
function send(tab){
browser.tabs.executeScript(tab, {
file: "/content_scripts/recorder.js",})
.then(function () { browser.tabs.sendMessage(tab, {record: "start"}) })
.catch(console.error.bind(console));
}
});
内容脚本:
(function() {
if (window.hasRun) {
return;
}
window.hasRun = true;
browser.runTime.onMessage.addListener(notify);
function notify(message){
alert(message.record);
}
})();
manifest.json:
{
"manifest_version": 2,
"name": "TW Recorder",
"version": "1.0",
"description": "Recorder.",
"icons": {
"48": "icons/border-48.png"
},
"permissions": [
"<all_urls>",
"activeTab",
"tabs",
"storage",
"webRequest"
],
"browser_action": {
"default_icon": "icons/border-48.png",
"default_title": "Recorder",
"default_popup": "popup/main.html"
},
"content_scripts": [
{
"matches": ["<all_urls>"],
"js": ["content_scripts/jquery-3.3.1.min.js","content_scripts/recorder.js"]
}
]
}
更正后的内容脚本(将 runTime 更改为运行时):
(function() {
if (window.hasRun) {
return;
}
window.hasRun = true;
browser.runtime.onMessage.addListener(notify);
function notify(message){
alert(message.record);
}
})();
我是 Firefox 扩展的新手。我试图在单击按钮时将消息从弹出脚本发送到内容脚本,但我收到此错误:
Could not establish connection. Receiving end does not exist.
我没有收到任何其他错误,所以我不确定为什么会出现此错误。
弹出脚本:
document.getElementById("rec").addEventListener("click", (e) => {
var query = browser.tabs.query({currentWindow: true, active : true});
var tab = query.then(getTab,onError);
function getTab(tabs) {
for (let tab of tabs){
send(tab.id);
}
}
function onError(error) {
console.log(`Error: ${error}`);
}
function send(tab){
browser.tabs.executeScript(tab, {
file: "/content_scripts/recorder.js",})
.then(function () { browser.tabs.sendMessage(tab, {record: "start"}) })
.catch(console.error.bind(console));
}
});
内容脚本:
(function() {
if (window.hasRun) {
return;
}
window.hasRun = true;
browser.runTime.onMessage.addListener(notify);
function notify(message){
alert(message.record);
}
})();
manifest.json:
{
"manifest_version": 2,
"name": "TW Recorder",
"version": "1.0",
"description": "Recorder.",
"icons": {
"48": "icons/border-48.png"
},
"permissions": [
"<all_urls>",
"activeTab",
"tabs",
"storage",
"webRequest"
],
"browser_action": {
"default_icon": "icons/border-48.png",
"default_title": "Recorder",
"default_popup": "popup/main.html"
},
"content_scripts": [
{
"matches": ["<all_urls>"],
"js": ["content_scripts/jquery-3.3.1.min.js","content_scripts/recorder.js"]
}
]
}
更正后的内容脚本(将 runTime 更改为运行时):
(function() {
if (window.hasRun) {
return;
}
window.hasRun = true;
browser.runtime.onMessage.addListener(notify);
function notify(message){
alert(message.record);
}
})();