javascript - Chrome 扩展程序键盘快捷键以错误的顺序显示

标签 javascript google-chrome-extension

我正在开发 Chrome 扩展程序并在本地进行测试。我在扩展 list 中以标准方式建立了 10 个左右的键盘快捷键列表,如下所示:

"commands":
    {
        "mute-all":
        {
            "description": "1 - Toggle \"Mute All Tabs\"",
            "suggested_key":
            {
                "default": "Ctrl+Shift+A",
                "mac": "Command+Shift+A"
            }
        },
        "unmute-all":
        {
            "description": "2 - Toggle \"Unmute All Tabs\"",
            "suggested_key":
            {
                "default": "Ctrl+Shift+Z",
                "mac": "Command+Shift+Z"
            }
        },
        "unmute-current":
        {
            "description": "3 - Toggle \"Always unmute current tab\"",
            "suggested_key":
            {
                "default": "Ctrl+Shift+S",
                "mac": "Command+Shift+S"
            }
        },
        "mute-others":
        {
            "description": "4 - Toggle \"Always mute all other tabs\"", 
            "suggested_key":
            {
                "default": "Ctrl+Shift+X",
                "mac": "Command+Shift+X"
            }
        },
        "use-black-list":
        {
            "description": "5 - Toggle \"Use Black/White List\""
        },
        "viewed-list":
        {
            "description": "6 - Aoggle viewed list"
        },
        "add-domain":
        {
            "description": "7 - Add domain to viewed list"
        },
        "remove-domain":
        {
            "description": "8 - Remove domain from viewed list"
        },
        "add-page":
        {
            "description": "9 - Add page to viewed list"
        },
        "remove-page":
        {
            "description": "10 - Remove page from viewed list"
        },
        "manual-override":
        {
            "description": "11 - Toggle manual override un/mute for current tab"
        }
    }

它们出现在 Chrome 的扩展程序键盘快捷菜单 (chrome://extensions/configureCommands) 中,但顺序出乎意料:

keyboard shortcuts

如何让它们按照我希望的顺序排列?他们不应该按描述的字母顺序排列吗?在我添加前面的数字以尝试强制执行我想要的顺序之前,它们似乎仍然与几个构建之前的顺序相同(根据描述大致按字母顺序排列)。

最佳答案

事实证明,显示的快捷方式的顺序是基于 list 文件中指定的内部命令名称,而不是描述。我花了一段时间才意识到这一点,但如果您查看我为命令提供的变量名称并按字母顺序对它们进行排序,它就会与屏幕截图中的顺序相匹配。

为了解决这个问题,我只是在命令名称前面加上数字,如下所示:

"01-mute-all":
{ ... },
"02-unmute-all":
{ ... },
"03-unmute-current":
{ ... },
"04-mute-others":
{ ... },
etc.

虽然我认为 Chrome 中的这种行为很愚蠢(它将后端变量名称链接到前端外观),但至少它是可以预见的。

我在这里提交了一个功能请求: https://bugs.chromium.org/p/chromium/issues/detail?id=732578

关于javascript - Chrome 扩展程序键盘快捷键以错误的顺序显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44507432/

相关文章:

javascript - 从 chrome 扩展内容脚本执行网页 js

javascript - 根据单选按钮选择切换 DIV 可见性

javascript - 对象属性在 chrome.storage.sync.set 后变为空

javascript - 安全覆盖 Google Chrome 扩展中的 document.cookie

javascript - Chrome 扩展程序包含错误

google-chrome-extension - 检测 Chrome 中的丰富通知是否可用

c# - javascript 服务器标签格式不正确

javascript - forEach() 是异步的吗?

javascript - Robots.txt 拒绝 #!网址

javascript - 需要多次