Google chrome 有没有办法从扩展名中编辑chrome扩展名清单文件?

Google chrome 有没有办法从扩展名中编辑chrome扩展名清单文件?,google-chrome,Google Chrome,我想允许用户从列表中选择为其分机显示的图标。有没有办法从扩展中编辑清单 因此,如果我的chrome扩展名清单文件中有以下内容: "browser_action": { "default_icon": "ico32.gif", } 我想让用户能够在扩展本身中将其更改为以下内容: "browser_action": { "default_icon": "ico32green.gif", } 有办法吗?没有办法直接编辑清单文件。但是,可以使用以下变通方法在浏览器加载

我想允许用户从列表中选择为其分机显示的图标。有没有办法从扩展中编辑清单

因此,如果我的chrome扩展名清单文件中有以下内容:

  "browser_action": {
    "default_icon": "ico32.gif",
  }
我想让用户能够在扩展本身中将其更改为以下内容:

  "browser_action": {
    "default_icon": "ico32green.gif",
  }

有办法吗?

没有办法直接编辑清单文件。但是,可以使用以下变通方法在浏览器加载时修改特性。此特定代码在浏览器加载时设置图标,并允许用户指定在浏览器加载时应设置的图标:

在manifest.json中:

{
  "browser_action": {
    "default_icon": "ico32.gif",
  },
  "options_page": "options.html",
  "background_page":"background.html"
}
在后台页面中:

<script>
var icon = localStorage["icon"];
if(icon == undefined){
    icon = "ico32.gif";
    localStorage["icon"] = icon;
}

chrome.browserAction.setIcon({"path":localStorage["icon"]});
</script>

var icon=localStorage[“icon”];
如果(图标==未定义){
icon=“ico32.gif”;
本地存储[“图标”]=图标;
}
chrome.browserAction.setIcon({“path”:localStorage[“icon”]});
在选项页中:

<html>
<body>
<h1>Choose you color:</h1>
<p>
    <img class="color" src="ico48.gif" />
    <img class="color" src="icoGreen.gif" />
    <img class="color" src="icoPurple.gif" />
    <img class="color" src="icoRed.gif" />
</p>
<script>
var colors = document.getElementsByClassName("color");
for(var i=0,ii=colors.length;i<ii;i++){
    colors[i].addEventListener("click", changeColor);
}

function changeColor(e){
    localStorage["icon"] = e.target.src;
    chrome.browserAction.setIcon({"path":localStorage["icon"]});
}
</script>
</body>
</html>

选择您的颜色:

var colors=document.getElementsByClassName(“颜色”); 对于(变量i=0,ii=colors.length;i