Chrome扩展程序切换选项卡:选项卡选择超时问题

时间:2013-07-24 10:04:09

标签: google-chrome google-chrome-extension

我创建了一个简单的扩展,可以在当前和最后一个聚焦选项卡之间切换。切换可以通过ALT+Q或通过单击扩展图标栏中的按钮来完成。只有一个问题。在当前选项卡上花费一定时间后,扩展似乎忘记了最后一个焦点选项卡。也就是说,我再也无法切换回最后一个焦点标签了。

任何人都可以请我解释为什么我的分机会忘记最后一个关注的标签吗?

// manifest.json

{    
    "background": {
        "scripts": ["background.js"],
        "persistent": false
    },
    "name": "Toggle Switch Recent Last Tabs",
    "version": "1.1",
    "manifest_version": 2,
    "description": "Toggle between your current and last used (focused) tab with a keyboard shortcut (ALT+Q by default) or mouse click on the icon.",
    "browser_action": {
        "default_title": "",
        "default_icon": "icon.png"
    },
    "commands": {
        "toggle": {
            "suggested_key": {
                "default": "Alt+Q"
            },
            "description": "Toggle tabs"
        }
    },
    "permissions": [
        "tabs", 
        "http://*/",
        "https://*/*"
    ],
    "icons": {
        "16": "icon_16.png",
        "32": "icon_32.png",
        "48": "icon_48.png",
        "128": "icon_48.png"
    }
}

background.js

// background.js

var previousTab;
var currentTab;

// General functions
chrome.browserAction.onClicked.addListener(function(tab) {
    chrome.tabs.update(previousTab, {selected: true});
});

chrome.tabs.onSelectionChanged.addListener(function(tab) {
    if (previousTab == null) {
        previousTab = tab;
    }
    if (currentTab == null) {
        currentTab = tab;
    }
    else {
        previousTab = currentTab;
        currentTab = tab;
    }
});


// Keyboard shortcut toggle function
chrome.commands.onCommand.addListener(function(command) {
  if (command == "toggle") {

    chrome.tabs.getSelected(null, function(tab) {
        previousTab = tab.id;
        currentTab = null;
    });

    chrome.tabs.update(previousTab, {selected: true});
  }
});

Download in Webstore

Complete source code

1 个答案:

答案 0 :(得分:2)

简而言之,你正在失去状态。可能是因为您的后台页面不是持久的(manifest.json中为persistent: false)。

此类页面称为Event page,而不是后台页面,为了提高效率,它会在几秒钟不活动后卸载,并在事件调用时重新加载。

这很奇怪,我必须解释一下:首先Chrome运行此页面只是为了注册听众。之后,页面被卸载,丢失全局变量,但Chrome记住了侦听器。当一个事件调用其中一个时,Chrome会加载整个事件页面,再次使用其初始值创建全局变量。

要解决此问题,请先尝试将persistent更改为true。如果有效,最好返回persistent: false并将变量(previousTab,currentTab)保存在存储中。

chrome.storage.local更快,更高效,但是异步。值得花一些时间让它发挥作用!