位置: IT常识 - 正文

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

编辑:rootadmin
chrome拓展插件开发中使用chrome.storage本地存储 一、描述

推荐整理分享chrome拓展插件开发中使用chrome.storage本地存储(chrome插件扩展名),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:chrome扩展插件网址,chrome插件扩展,chrome插件扩展名,chrome拓展插件怎么用,chrome打开插件,chrome插件扩展名,chrome打开插件,chrome拓展程序在哪,内容如对您有帮助,希望把文章链接给更多的朋友!

在扩展程序中本地存储数据可以通过 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.syncchrome拓展插件开发中使用chrome.storage本地存储(chrome插件扩展名)

如果需要将存储的内容同步到所有登录了同一账号的 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、removebutton6.onclick = () => { chrome.storage.local.remove('textValue', function() { console.log('remove '); });}

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

本文链接地址:https://www.jiuchutong.com/zhishi/288077.html 转载请保留说明!

上一篇:30个极致实用的谷歌浏览器插件,让你开发事半功倍(30个极致实用的东西)

下一篇:一篇文章带你解1+X Web 前端开发考核考纲(详细介绍)(涵盖初级、中级、高级)(解读一篇文章)

  • 微博如何设置赞不可见(微博如何设置赞过的微博)

  • 拼多多步数在哪里(拼多多步数在哪里关闭OPPO)

  • cad光标不受控制的晃动(cad光标不受控制怎么设置)

  • ufs3.0读写速度(ufs2.1读写速度)

  • 为什么qq加群要发短信(为什么qq加群要验证码)

  • ipadpencil第一次线充要多久(ipadpencil第一次充电多久)

  • 蓝牙配对是什么意思(蓝牙配对有什么用处)

  • 情侣空间为什么开不了(情侣空间为什么别人看不见)

  • p30微信视频美颜怎么打开(p30微信视频美颜在哪里)

  • 4g的手机能用5g吗(4g的手机能用5g的卡吗)

  • 移动硬盘坏了数据可以恢复吗(移动硬盘坏了数据可以导出来吗)

  • wps屏幕录制的视频没有声音(wps屏幕录制的视频在哪儿)

  • 电脑屏幕分辨率怎么调都不对(电脑屏幕分辨率调整不了怎么办)

  • 天然气set什么意思(天然气显示close)

  • 安卓手机提示内存不足怎么办(安卓手机提示内存空间不足怎么办)

  • 苹果手机如何关闭wlan(苹果手机如何关屏幕)

  • 手机进水有杂音怎么办(手机进水有杂音过几天会好吗?)

  • 苹果8pdock栏设置透明(iphone8dock栏)

  • 华为荣耀20怎么插耳机(华为荣耀20怎么刷机)

  • 手机删掉的软件怎么找回来(手机删掉的软件怎么找回)

  • m和mb流量哪个大(m和mb流量哪个大些)

  • 小米9的前后摄像头像素是多少(小米9的前后摄像头在哪)

  • a1534是什么型号(a1534是什么配置)

  • word怎么设置标题等级(word怎么设置标题级别)

  • 怎么恢复微信聊天记录(怎么恢复微信聊天背景默认)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络