[英]Listen for message in content script from addon code
附加码,
创建一个Panel
,由confirmPanel.html
填充
侦听来自内容脚本的getPreferences
消息,
构建一个JSON字符串,然后尝试发送回内容脚本..
var confirmPanel = require("sdk/panel").Panel({
width: 450,
height: 350,
contentURL: Data.get("confirmPanel.html"),
});
confirmPanel.port.on("getPreferences", function() {
var prefs = '{'
+'"fileName":"HelloWorld.txt", '
+'"pathToFile":"/home/rob/", '
+'}';
confirmPanel.port.emit("prefs", prefs);
})
confirmPanel.html
指定Panel
内容..
<html>
<head>
<script src="confirmPanel.js"></script>
</head>
<body onload="Addon_Panel.getPreferences()">
</body>
</html>
confirmPanel.js
是为内容脚本confirmPanel.html
等待body
加载,然后将getPreferences
消息发送到附加代码。
然后等待插件代码中的prefs
消息将JSON字符串记录到控制台
但是console.log(prefs);
永远不会执行?
var Addon_Panel = {
getPreferences: function() {
addon.port.emit("getPreferences", '');
}
};
addon.port.on("prefs", function (prefs) {
console.log(prefs);
});
将内容脚本附加为文件,而不是将其包含在html中
main.js
var confirmPanel = require("sdk/panel").Panel({
width: 450,
height: 350,
contentURL: Data.get("html/confirmPanel.html"),
contentScriptFile: [Data.get("js/confirmPanel.js")]
});
confirmPanel.port.emit("prefs", prefs);
在内容脚本文件中..
self.port.on("prefs", function (prefs) {
console.log("in content script");
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.