2012-06-03 228 views
3

构建我的Google Chrome浏览器扩展程序时,遇到存储其设置的问题。我在用户点击browserAction图标后创建了一个在选项卡中打开的设置页面。此页面具有用于设置我的扩展的UI,并且它可以将设置存储到localStore中。但是我的扩展的后台页面,它应该读取这些设置,没有任何localStore。Chrome扩展程序商店

我应该在哪里存储扩展设置,以便它可以从浏览器的任何地方访问并永久保存?

感谢您的帮助......

+1

其实,你的背景页面应该存储设置并将它们读出来供各种请求它的设备使用。即使配置页面也必须从后台页面获取/设置设置。可能是http://stackoverflow.com/questions/1961544/communication-between-the-options-page-and-background-page-in-google-chrome可以提供帮助。 – SuperSaiyan

回答

1

如果你想使用你的backgroundpage即暂时存储数据:

// in your backgroundpage 
// Set a value 
window['yourvalue']=123; 
// Get a value 
alert(window['yourvalue']); 

// in any other page (options/popup/message/whatever) 
var bg=chrome.extension.getBackgroundPage(); 
// Set a value 
bg['yourvalue']=123; 
// Get a value 
alert(bg['yourvalue']); 

我总是在我的扩展使用这些功能:

var bg=chrome.extension.getBackgroundPage(); 
// Save data 
function save(key, val) { 
    bg[key]=val; 
    var data={}; 
    var tmp=localStorage.getItem("MyPlugin"); 

    if(tmp!=null&&tmp.indexOf("{")>-1&&tmp.indexOf("}")>-1) 
    { 
     data=JSON.parse(tmp); 
    } 
    data[key]=val; 
    localStorage.setItem("MyPlugin", JSON.stringify(data)); 
} 

// Restore the data 
var data={}; 
var tmp=localStorage.getItem("MyPlugin"); 

if(tmp!=null&&tmp.indexOf("{")>-1&&tmp.indexOf("}")>-1) 
{ 
    data=JSON.parse(tmp); 
    for (var key in data) { 
     if (data.hasOwnProperty(key)) { 
      bg[key]=data[key]; 
     } 
    } 
}