跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 卖家故事 > chrome拓展插件开发中使用chrome.storage本地存储

chrome拓展插件开发中使用chrome.storage本地存储

时间:2024-04-05 19:10:29 来源:网络cs 作者:晨起 栏目:卖家故事 阅读:

标签: 使用  本地 
阅读本书更多章节>>>>

一、描述

在扩展程序中本地存储数据可以通过 chrome.storage API 实现,和 web 中的 localstorage 在某些方面是有区别的,chrome.storage 已经做了优化。

与 localStorage 的区别:

用户数据可以与 chrome 自动同步(通过 storage.sync),只要用户登录了 chrome 账号,则能够全量同步浏览器扩展程序的脚本能够直接访问用户的数据,不需要通过 background js即使使用 split 隐身行为,也可以保留用户的扩展程序设置异步批量读写操作,比阻塞和串行的 localStorage 更快用户数据可以存储对象(localStorage 是将对象 string 到字符串中)可以读取管理员为扩展配置的企业策略(使用带有模式的 storage.managed 做 schema)

二、权限申请

如果要使用 chrome.storage 则需要在 manifest 的 permissions 申请:

三、local 与 sync 的使用不同

使用 storage.sync 时,如果用户启用了同步,则存储的数据将自动同步到用户登录的任何 Chrome 浏览器。

当 Chrome 处于离线状态时,Chrome 会在本地存储数据。下次浏览器在线时,Chrome 会同步数据。即使用户禁用同步,storage.sync 仍然可以工作。在这种情况下,它的行为与 storage.local 相同。

storage.managed 是只读的

存储是未加密的,不能存储机密信息

1、chrome.storage.sync

如果需要将存储的内容同步到所有登录了同一账号的 chrome 浏览器中,可以通过 chrome.storage.sync

// popup.jsbutton.onclick = () => {    chrome.storage.sync.set({key: 'value11'}, () => {        console.log('set successed!');    });}button2.onclick = () => {    chrome.storage.sync.get('key', (res) => {        console.log(res);    });}

 结果展示:

 

 

2、chrome.storage.local

button3.onclick = () => {    chrome.storage.local.set({key: "value local"}, function() {        console.log('Value is set to ' + value);    });    chrome.storage.local.get(['key'], function(result) {        console.log('Value currently is ' + result.key);    });}

结果展示:

 

 

四、存储限制

chrome.storage 的存储是有限制的,类似一个管道。

当管道满了之后,就会排队,因此可能无法继续存储。

五、使用示例及存储对象变更监听

存储内容变更之后,是能够监听到事件的,比如我做了下面的存储。

    const text = textarea.value;    chrome.storage.local.set({'textValue': text}, function() {        console.log('Value is ' + text);    });

可以通过如下监听:

chrome.storage.onChanged.addListener(function(changes, namespace) {        for (var key in changes) {          var storageChange = changes[key];          console.log('Storage key "%s" in namespace "%s" changed. ' +                      'Old value was "%s", new value is "%s".',                      key,                      namespace,                      storageChange.oldValue,                      storageChange.newValue);        }      });

六、API 示例

set 和 get 上面已经有了,不重复

remove 和 get 两个方法均支持 单个参数或者是数组形式的参数

1、remove

button6.onclick = () => {    chrome.storage.local.remove('textValue', function() {        console.log('remove ');    });}

2、clear

button7.onclick = () => {    chrome.storage.local.clear(function() {        console.log('remove all ');    });}

阅读本书更多章节>>>>

本文链接:https://www.kjpai.cn/gushi/2024-04-05/154561.html,文章来源:网络cs,作者:晨起,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论