我正在尝试从上下文菜单onclick事件中的后台脚本中接收来自我的内容的消息。这是内容脚本:
var clickedEl = null;
document.addEventListener("mousedown", function(event){
if(event.button == 2) {
clickedEl = event.target;
console.log("event.target = "+event.target);
}
}, true);
chrome.extension.onMessage.addListener(function(request, sender, sendResponse) {
if(request == "getClickedEl") {
console.log("requestValue = " + clickedEl);
sendResponse({value: clickedEl.value});
}
});
这是我的后台脚本,我在单击上下文菜单时将消息发送到内容脚本。
function doScripts(context, targ){
chrome.tabs.executeScript(null, {code: "var doingBrowserAction = "+(context)+"; var contextTarg = "+(targ)+";"}, function(){
chrome.tabs.executeScript(null, {file: "js/myscript.js"}, function(){});
});
}
function getClickHandler(info, tab) {
chrome.tabs.sendMessage(tab.id, "getClickedEl", function(clickedEl) {
var currTarg = clickedEl.value;
doScripts(false, currTarg);
});
}
chrome.contextMenus.create({
"title" : "DESTROY!",
"type" : "normal",
"contexts" : ["page","selection","link","editable","image","video","audio"],
"onclick" : getClickHandler
});
我确认正在使用
从后台脚本调用onMessageconsole.log("requestValue = " + clickedEl);
在onMessage
听众中,这是有效的。我的主要问题是当我在后台脚本上获得变量时它出现为null,当我尝试将变量传递给doScripts
函数时,它不起作用。我认为我正在解析消息的方式在接收端遇到问题,但我不确定我做错了什么。