bkv*_*chu 3 javascript google-chrome google-chrome-extension
如标题中所述,我正在尝试编写一个后台脚本,该脚本将侦听来自popup.js或contentscript.js的加载请求.当它收到一个加载时,它获取chrome.storage.local的内容,执行一些数据处理(for循环)并将其发送给请求者.
当前的问题,是我的代码收到请求,但无法发回数据.我的代码如下:
popup.js:
chrome.runtime.sendMessage({greeting: "Load"}, function(response) {
console.log(response);
}
Run Code Online (Sandbox Code Playgroud)
background.js:
chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
if(request.greeting=='Load') {
chrome.storage.local.get(null,function(storeObject){
var newList=[];
//Perform some dataprocessing to store part of storeObject into newList
sendResponse(newList);
});
}
});
Run Code Online (Sandbox Code Playgroud)
我认为这个问题与范围有关,因为调试后看起来像sendResponse试图从chrome.storage而不是background.js发送.此外,如果我在chrome.storage.local回调之外(之前/之后)发送消息,popup.js会收到消息.无论如何,我很遗憾该怎么做才能使此消息通过工作,并希望得到任何帮助.
gka*_*pak 12
根据`chrome.runtime.onMessage上的文档:
sendResponse(function)
[...] 当事件监听器返回时,此函数变为无效,除非您从事件监听器返回true表示您希望异步发送响应(这将使消息通道保持打开到另一端,直到sendResponse叫做).
因为,sendResponse在chrome.storage.local.get()回调中异步调用,所以需要从onMessage侦听器返回true 以防止函数失效.
chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
if (request.greeting === 'Load') {
chrome.storage.local.get(null, function(storeObject) {
...
sendResponse(newList);
});
return true; // <-- I intend to call `sendResponse` later
}
return false; // <-- I do NOT intend to call `sendResponse`
});
Run Code Online (Sandbox Code Playgroud)