首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Chrome扩展设置

Chrome扩展设置
EN

Stack Overflow用户
提问于 2015-01-18 03:02:23
回答 3查看 1.7K关注 0票数 1

我需要制作一个只运行一次的javascript函数,这样它就可以设置一堆google变量,有人知道怎么做吗?

这是我现在所拥有的,但我不认为它有用:

代码语言:javascript
复制
window.onLoad = check();

function check() {
    chrome.storage.local.get('defaultLoad', function (x) {
        if (x.defaultLoad == undefined) {
            chrome.storage.local.set({'defaultLoad': '0'}, function() {
                console.log('SearchPanel default');
                defaultLoad();
            });
        }
    });
}

function defaultLoad() {
    chrome.storage.local.set({'searchPanelOption': 'open'}, function() {
            console.log('SearchPanel default');
    });
    chrome.storage.local.set({'barBackgroundOption': '#000000'}, function() {
            console.log('barBackground default');
    });
    chrome.storage.local.set({'goBackgroundOption': '#000000'}, function() {
            console.log('goBackground default');
    });
    chrome.storage.local.set({'barColorOption': '#ffffff'}, function() {
            console.log('barColor default');
    });
    chrome.storage.local.set({'placeColorOption': '#999999'}, function() {
            console.log('placeColor default');
    });
    chrome.storage.local.set({'searchEngineOption': 'google'}, function() {
            console.log('searchEngine default');
    });
}

该脚本在页面顶部被调用,它应该只运行一次,但我认为它不起作用,因为我没有得到任何console.log输出。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-01-18 06:58:29

因此,您希望设置默认值。

在分隔的文件中定义默认值。

代码语言:javascript
复制
// Define default values.
var options = {
    notifyTimeout: 5,
    pageInspect: true,
    linkInspect: true,
    pushItem: false,
    notifyMode: 'margin',
};

// a method similar to jquery.ready
function initOptions(callback) {
    // get data from remote
    chrome.storage.sync.get(null, function(data) {
        // merge remote data into local global `options`
        $.extend(options, data);
        // push them back to remote
        // maybe the extension updated and added new default values.
        chrome.storage.sync.set(options);
        // callback method to use updated options.
        callback && callback();
    });
}

// listen to remote data changes, if soem value changed
// update the global variable `options`, for example,
// you changed an option in options page and push changes to remote
// in contentscript, this got the changes and update to new value.
// you can use the updated value without a page reload.
chrome.storage.onChanged.addListener(function(changes) {
    for (var name in changes) {
        var change = changes[name];
        options[name] = change.newValue;
    }
});

在页面中,您想要使用选项,注入这个脚本,并且可以随意使用全局变量options,它也适用于内容脚本。

代码语言:javascript
复制
initOptions(function() {
   doSomethingWith(options); 
});

我写了一篇关于这个的文章,但不是用英语写的。

http://www.g2w.me/2014/08/sync-chrome-extension-options/

票数 3
EN

Stack Overflow用户

发布于 2015-01-18 12:03:09

只有在初始安装时才运行一个事件:

代码语言:javascript
复制
chrome.runtime.onInstalled.addListener(function(details) {
  if(details.reason == "install") {
    // This code runs once
  }
});

但是,presented by greatghoul方法更适合设置默认选项。它将覆盖任何没有被默认设置的选项,并保留已经设置的任何选项的值。这样做更好,因为之后添加更多选项就像向默认选项添加新键一样简单。

票数 1
EN

Stack Overflow用户

发布于 2015-01-18 03:30:30

但是,这段代码确实有效,您只需将函数调用defaultLoad()移出chrome.local.storage.set调用。

代码语言:javascript
复制
window.onLoad = check();

function check() {
    chrome.storage.local.get('defaultLoad', function (x) {
        if (x.defaultLoad == undefined) {
            chrome.storage.local.set({'defaultLoad': '0'}, function() {
                console.log('SearchPanel default');
            });
            defaultLoad();
        }
    });
}

function defaultLoad() {
    chrome.storage.local.set({'searchPanelOption': 'open'}, function() {
            console.log('SearchPanel default');
    });
    chrome.storage.local.set({'barBackgroundOption': '#000000'}, function() {
            console.log('barBackground default');
    });
    chrome.storage.local.set({'goBackgroundOption': '#000000'}, function() {
            console.log('goBackground default');
    });
    chrome.storage.local.set({'barColorOption': '#ffffff'}, function() {
            console.log('barColor default');
    });
    chrome.storage.local.set({'placeColorOption': '#999999'}, function() {
            console.log('placeColor default');
    });
    chrome.storage.local.set({'searchEngineOption': 'google'}, function() {
            console.log('searchEngine default');
    });
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28006730

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档