所以,我知道你不能同时拥有后台脚本和默认弹出窗口。如果是这样,我怎么能有类似于默认弹出窗口(当你点击扩展名的图标时出现一些简单的HTML)并让后台脚本修改该弹出窗口的内容?
这是manifest.json
"browser_action": {
"default_title": "Mark this position!",
"default_icon": "icon.png"
},
"background": {
"scripts": ["background.js"],
"persistent": false
},
"content_scripts": [
{
"matches": [
"http://*/*",
"https://*/*"
],
"js": ["content.js"]
}
],
答案 0 :(得分:5)
您绝对可以同时拥有弹出窗口(即default_popup
设置)和背景页面。后台页面将有自己的生命周期("persistent": false
只有Event page),弹出窗口只要打开就会存在。
我猜你的困惑源于你不能同时拥有弹出窗口和chrome.browserAction.onClicked
监听器这一事实。
这是事实,但还有其他方法可以告诉您的后台页面弹出窗口已打开。
您可以从弹出窗口中发送背景信息:
// popup.js, should be included in the popup
chrome.runtime.sendMessage({popupOpen: true}, function(response) {
/* process response */
});
// background.js
chrome.runtime.onMessage.addListener(function(message, sender, sendResponse) {
if(message.popupOpen) {
/* do stuff */
sendResponse(response);
}
});
如果您将上面的弹出式代码放在顶层,则弹出窗口打开后会立即通知后台。
虽然您可以直接从后台访问弹出窗口(请参阅chrome.extension.getViews
),但建议您将UI逻辑移动到弹出窗口中并使用{与背景进行通信{3}}如上所述并分享Messaging。