等待chrome.tabs.query回调的最佳方法是什么?

时间:2013-09-03 12:46:10

标签: javascript google-chrome-extension

我正在编写一个Chrome扩展程序供我自己使用。我正在从注入的脚本中查询当前选项卡的索引,如下所示:

[注入脚本]

chrome.runtime.sendMessage({whatIsMyIndex:1}, function(response){
   var myIndex = response.index;
});

[后台脚本]

chrome.runtime.onMessage.addListener(
   function(request, sender, sendResponse) {
      if (request.whatIsMyIndex){
         sendResponse({index: sender.tab.index});
      }
   }
);

现在这一切都很好,但我还需要返回第一个标签的网址:

[注入脚本2]

chrome.runtime.sendMessage({whatIsMyIndex:1}, function(response){
   var myIndex = response.index;
   var url = response.url;
});

[后台脚本2]

var url;

//this uses sendResponse when the requested values arrive
function respond(sendResponse, index){
   if(typeof(url)!="undefined"){
      sendResponse({index:index, url:url});
   } else {
      setTimeout(respond, 15, sendResponse, index);
   }
}

chrome.runtime.onMessage.addListener(
   function(request, sender, sendResponse) {
      if (request.whatIsMyIndex){
         chrome.tabs.query({index:0, currentWindow:true}, function(tabs){
            url=tabs[0].url;
         }
         setTimeout(respond, 15, sendResponse, sender.tab.index);
         return true; //so i can use sendResponse later
      }
   }
);

现在,这段代码运行得很好。 我的问题是,有没有办法在不需要setTimeout的情况下实现这一目标?添加固定的15ms延迟似乎不对。

如果我能得到chrome.tabs.query的回调以把我的sendResponse()作为参数......

(在全局变量中存储sendResponse()是不可能的,因为会有~20个标签同时执行此操作,并且所有标签都需要自己的响应。)

我这里不需要任何工作(或不工作)代码,只需要一些想法/指导。

1 个答案:

答案 0 :(得分:7)

只需在sendResponse回调中调用chrome.tabs.query,而不是设置变量:

chrome.runtime.onMessage.addListener(
   function(request, sender, sendResponse) {
      if (request.whatIsMyIndex){
         chrome.tabs.query({index:0, currentWindow:true}, function(tabs){
            sendResponse({index:sender.tab.index, url:tabs[0].url});
         });
         return true; //so i can use sendResponse later
      }
   }
);

每次调用onMessage回调函数都会创建一个新的闭包,因此sendResponse回调函数中的tabs.query将绑定到正确的函数。