如何从后台页面获取当前tabId?current tabId是用户可以查看其内容的选项卡。
background.html
<html>
<head>
<script>
if(typeof localStorage.state == 'undefined')
localStorage.state = 'off'
chrome.browserAction.onClicked.addListener(function(tab) {
if(localStorage.state == 'on')
{
localStorage.state = 'off';
}
else
{
localStorage.state = 'on';
}
chrome.browserAction.setBadgeText({text: localStorage.state, tabId: tab.id});
chrome.tabs.sendRequest(tab.id, {state: localStorage.state});
//chrome.tabs.sendRequest(tab.id, {state: localStorage.state});
});
</script>
</head>
发布于 2012-08-22 01:51:10
getSelected
已经被deprecated了。新的方法是:
chrome.tabs.query(
{currentWindow: true, active : true},
function(tabArray){...}
)
如果您想在活动选项卡上执行一些回调,您可以按如下方式包装上述内容:
function doInCurrentTab(tabCallback) {
chrome.tabs.query(
{ currentWindow: true, active: true },
function (tabArray) { tabCallback(tabArray[0]); }
);
}
例如
var activeTabId;
doInCurrentTab( function(tab){ activeTabId = tab.id } );
发布于 2013-08-20 08:58:50
在您的后台页面中运行此程序
chrome.tabs.query({active:true,windowType:"normal", currentWindow: true},function(d){console.debug(d);})
甚至更好
chrome.tabs.query({active:true,windowType:"normal", currentWindow: true},function(d){console.debug(d[0].id);})
发布于 2011-09-05 10:49:18
许多API方法将null
解释为当前选项卡。chrome.tabs.sendRequest
就是其中之一。
否则:
chrome.tabs.getSelected(null, function(tab) { ... })
https://stackoverflow.com/questions/7303452
复制相似问题