所以我知道怎么换分机的图标-
chrome.browserAction.setIcon({
path : "green.png"
});但是,我怎样才能做到不改变图标,而是在浏览器中添加一个小图像呢?我真的不知道该怎么称呼它。它类似于扩展"AdBlock“,其中它有它的图标,然后一个数字在左下角图标告诉你有多少广告被屏蔽。
对于我的扩展,我试图通过在扩展的浏览器中图标上显示一个绿色/黄色/红色的方块来显示扩展的“状态”。
我如何做到,比如说,在图标左下角弹出一个绿色方块,类似于被屏蔽的广告数量?现在,我有3种不同的图像,我将图标更改为相应的图像,但我觉得有一种更直观的方法来做到这一点。
编辑:
所以我想出了这个代码,但是不管我做什么,徽章的颜色都是红色的-
chrome.browserAction.setBadgeText( { text: " " } );
function setIconStatus(status){
if (status == 1){
chrome.browserAction.setBadgeBackgroundColor({color:"green"})
} else if (status == 0){
chrome.browserAction.setBadgeBackgroundColor({color:"red"})
} else {
chrome.browserAction.setBadgeBackgroundColor({color:"yellow"})
}
}我发现控制台出了问题-
Unchecked runtime.lastError while running browserAction.setBadgeBackgroundColor: Unknown error.
at setIconStatus (chrome-extension://blnceljpkdfniagjdagcnfeceanjcipe/rap.js:17:24)
at chrome-extension://blnceljpkdfniagjdagcnfeceanjcipe/rap.js:86:3reportIfUnchecked @ extensions::lastError:133handleResponse @ extensions::sendRequest:78jquery.js:5 POST https://shibboleth.buffalo.edu/idp/Authn/Stateless 500 (内部服务器错误)x.support.cors.e.crossDomain.send@ jquery.js:5x.extend.ajax @jquery.js:5x(匿名函数)@ jquery.js:5 (匿名函数)@ rap.js:116l @ jquery.js:3c.fireWith @ jquery.js:3k @jquery.js:5(匿名函数)@jquery.js:5
发布于 2016-03-07 20:19:44
因为您只是希望出现一个有色的框:
var status = " ";
chrome.browserAction.setBadgeText( { text: status } );
// Red, Green, Blue, Alpha
chrome.browserAction.setBadgeBackgroundColor({color: [0,255,0,255]});除此之外,还可以使用html画布元素对图标图像进行动态更改。然后用编辑的图像更新browseActionIcon。
发布于 2016-03-09 01:16:24
目前,chrome.browserAction.setBadgeBackgroundColor(object细节)不支持css样式颜色关键字。
如https://developer.chrome.com/extensions/browserAction#method-setBadgeBackgroundColor所述,您可以使用十六进制RGB值或颜色数组。
发布于 2022-01-24 15:14:10
注意:如果您使用的是V3,则该API已更改为:
..。统一 ..。
参考文献:Migrating to Manifest V3 (MV3) >> Action API unification
如果尝试将pageAction或browserAction与MV3一起使用,您将收到以下错误:
Error handling response: TypeError: Cannot read properties of undefined (reading 'setIcon')https://stackoverflow.com/questions/35852715
复制相似问题