c00*_*0fd 21 javascript google-chrome race-condition google-chrome-extension
我正在编写我的Google Chrome扩展程序,我在后台脚本中设置了应用程序的图标:
try
{
objIcon = {
"19": "images/icon19.png",
"38": "images/icon38.png"
};
chrome.browserAction.setIcon({
path: objIcon,
tabId: nTabID
});
}
catch(e)
{
}
Run Code Online (Sandbox Code Playgroud)
请注意,我在try/catch块中包装了调用.
不过,有时我在控制台日志中收到以下消息:
运行browserAction.setIcon时未选中runtime.lastError:没有标识为:11618的选项卡.
调试此错误很难,因为它似乎只在我关闭或重新加载Chrome标签时出现,它没有行号或任何信息供我跟踪,而且通过调试器运行并不容易(即我不能在发生错误时设置断点,但如果我在线上盲目设置断点chrome.browserAction.setIcon(),我就不再在日志中看到该消息了.)
所以我很好奇是否有人可以建议如何解决这个错误?
编辑:只是发布更新.我仍然无法解决此问题.@abraham在下面提出的建议提供了一种有点工作的方法,但它并非失败安全.例如,在标签关闭的情况下,我可以调用他的建议chrome.browserAction.setIcon(),如果标签尚未关闭,可能会成功,但在其回调函数中,标签最终可能会关闭,因此任何连续调用其他API需要相同的标签ID,说setBadgeBackgroundColor()可能仍然给我相同的No tab with id例外.换句话说,对于那些了解本土编程的人来说,这是一种典型的竞争条件.而且我不确定它是否是Chrome中的一个错误,因为很明显JS不提供任何线程同步方法......
在进行测试时,我已经多次目睹了这种行为.它并不经常发生,因为我们谈论的是非常精确的时序情况,但它确实发生了.因此,如果有人找到解决方案,请在下面发布.
abr*_*ham 24
包括回调并检查chrome.runtime.lastError.
objIcon = {
"19": "images/icon19.png",
"38": "images/icon38.png"
};
function callback() {
if (chrome.runtime.lastError) {
console.log(chrome.runtime.lastError.message);
} else {
// Tab exists
}
}
chrome.browserAction.setIcon({
path: objIcon,
tabId: nTabID
}, callback);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11414 次 |
| 最近记录: |