1

我创建了一个简单的扩展,可以在当前和最后一个焦点选项卡之间切换。切换可以通过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});
  }
});

在网上商店下载

完整的源代码

4

1 回答 1

2

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

这种页面称为事件页面,而不是背景页面,为了提高效率,它会在几秒钟不活动后卸载,并在事件调用时重新加载。

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

要修复它,首先尝试更改persistenttrue. 如果它有效,最好返回persistent: false并将您的变量(previousTab,currentTab)保存在存储中。

chrome.storage.local更快,更高效,但异步。值得花几分钟让它工作!

于 2013-07-24T11:45:25.870 回答