位置: 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 前端开发考核考纲(详细介绍)(涵盖初级、中级、高级)(解读一篇文章)

  • 小米mix4智能充电保护怎么开启(小米mix4智能充电保护作用)

    小米mix4智能充电保护怎么开启(小米mix4智能充电保护作用)

  • 苹果8p怎么装两张卡(苹果8p怎么装两个手机卡)

    苹果8p怎么装两张卡(苹果8p怎么装两个手机卡)

  • 目前在internet上应用最广泛的服务是(在internet中)

    目前在internet上应用最广泛的服务是(在internet中)

  • 荣耀30手机卡怎么插(荣耀手机卡怎么办)

    荣耀30手机卡怎么插(荣耀手机卡怎么办)

  • 戴尔电脑开机重复8声嘟嘟(戴尔电脑开机重装系统按F几?)

    戴尔电脑开机重复8声嘟嘟(戴尔电脑开机重装系统按F几?)

  • 小米10青春版是双扬声器吗(小米10青春版是什么处理器)

    小米10青春版是双扬声器吗(小米10青春版是什么处理器)

  • 骁龙765相当于麒麟多少(骁龙765相当于麒麟什么处理器)

    骁龙765相当于麒麟多少(骁龙765相当于麒麟什么处理器)

  • 苹果11键盘怎么换行(苹果11键盘怎么设置图片背景)

    苹果11键盘怎么换行(苹果11键盘怎么设置图片背景)

  • 4g+hd是什么(4ghd是什么意思收费吗)

    4g+hd是什么(4ghd是什么意思收费吗)

  • 如何选择笔记本电脑(如何选择笔记本显卡)

    如何选择笔记本电脑(如何选择笔记本显卡)

  • 华为荣耀20有没有原装耳机(华为荣耀20有没有语音唤醒功能)

    华为荣耀20有没有原装耳机(华为荣耀20有没有语音唤醒功能)

  • ipad没电要充多久开机(ipad没电充多久可以开机)

    ipad没电要充多久开机(ipad没电充多久可以开机)

  • 苹果11通话记录保存多久(苹果11通话记录怎么查询更早)

    苹果11通话记录保存多久(苹果11通话记录怎么查询更早)

  • ios6怎么设密码(苹果六如何设置密码)

    ios6怎么设密码(苹果六如何设置密码)

  • 苹果app扣款多少时间处理(苹果app扣费多久退款)

    苹果app扣款多少时间处理(苹果app扣费多久退款)

  • 苹果11pro max是5g手机吗(苹果11pro Max是防水的吗)

    苹果11pro max是5g手机吗(苹果11pro Max是防水的吗)

  • 拼多多新用户能砍多少(拼多多新用户能领多少现金)

    拼多多新用户能砍多少(拼多多新用户能领多少现金)

  • 网络电视画面不动了怎么办(网络电视画面不动是什么原因?)

    网络电视画面不动了怎么办(网络电视画面不动是什么原因?)

  • 如何更换唯品会登录名(如何更换唯品会购货城市)

    如何更换唯品会登录名(如何更换唯品会购货城市)

  • iphone9为什么跳过了(为什么苹果老是跳屏)

    iphone9为什么跳过了(为什么苹果老是跳屏)

  • 闲鱼本次付款不支持信用卡(闲鱼买家付款了显示未付款)

    闲鱼本次付款不支持信用卡(闲鱼买家付款了显示未付款)

  • 网络运营商认证失败是怎么回事(网络运营商认证app)

    网络运营商认证失败是怎么回事(网络运营商认证app)

  • 微信电话怎么看谁挂的(微信电话怎么看是谁先挂的)

    微信电话怎么看谁挂的(微信电话怎么看是谁先挂的)

  • uniapp实现app检查更新与升级-uni-upgrade-center详解(uniapp登陆检查)

    uniapp实现app检查更新与升级-uni-upgrade-center详解(uniapp登陆检查)

  • 一只正在花园里吃野苹果的乌鸫,英国威尔特郡 (© Nick Upton/Minden Pictures)(一只猫在花园里英语)

    一只正在花园里吃野苹果的乌鸫,英国威尔特郡 (© Nick Upton/Minden Pictures)(一只猫在花园里英语)

  • 承租方支付租房税费
  • 银行手续费回单可以作为入账依据吗
  • 土地增值税计算题
  • 红冲以后怎么做账
  • 增值税专用发票可以开电子发票吗
  • 机器设备折旧费用属于间接生产费用
  • 贷款应计利息会计分录
  • 增值税认证逾期怎么处理
  • 递延收益是什么表
  • 买的厨房用品算什么费用
  • 个人保证金业务
  • 大病医疗保险为什么贵
  • 机打发票多久可以作废
  • 进项大于销项的分录怎么写
  • 一般纳税人取得小规模纳税人的专票可以抵扣吗
  • 建筑企业财务制度及规范流程
  • 印花税税基含不含增值税
  • 加计抵减什么时候做账务处理
  • 管理费用销售费用
  • 企业的主营业务收入
  • 产业扶持周转金退回多久到账
  • 体育用品怎么才能买到
  • 软件行业研发费用比例有要求么
  • 分公司是否可以与劳动者建立劳动关系
  • 外籍人士离职补偿
  • 净资产是所有者权益一样吗
  • 票据贴现业务的风险
  • 如何固定iPhone墙纸
  • 个人所得税计算方法及抵扣方法
  • bios怎么恢复出厂设置会怎么样
  • nvcpl.dll是什么
  • w10如何删除微软拼音
  • PHP:oci_field_type()的用法_Oracle函数
  • linux root 命令
  • nodejs怎么更新版本
  • 利用php判断是否为素数
  • 个税专项扣除中赡养老人
  • php底层原理
  • 法人提取备用金多久归还
  • 小规模纳税人残保金申报时间
  • 个体户可以不办公户吗
  • 《网络安全从入门到精通》
  • 人人都能用英语pdf下载
  • php不执行
  • mlocate.db 删除
  • 对方代垫保险费算不算入账价值
  • 非居民纳税人183天新税法
  • 发票的普票和专票什么区别
  • python中的列表和元祖有什么区别
  • RabbitMQ个人实践
  • 差旅费单子格式表
  • 企业弥补以前年度亏损要怎么填表
  • 个人咨询费发票怎么开
  • 银行手续费如何做账务处理
  • 小规模纳税人减按1%怎么计算
  • 原始股卖出需要缴税吗
  • 待抵扣进项税额分录
  • 公户的利息收入账务处理咋处理
  • 生物资产转让增值税
  • 质量问题举例
  • mysql 左链接 右链接
  • xp系统没有声音没有音频设备
  • 网站的运维
  • win8不能安装软件
  • ext.formpanel
  • node.js模块化
  • Unity3D游戏开发毕业论文
  • 隐藏磁盘空间
  • unity4.5.3f3 和 Android的通信
  • javascript基础笔记
  • jquery1.8
  • nodejs一键安装
  • nodejs快速入门
  • jquery 添加
  • python文件与目录操作
  • jquery的实现原理
  • 税控盘税务数字证书密码忘记怎么办
  • 广东省电子税务局app下载官网
  • 即征即退什么时候退
  • 山东省地方税务局历任局长
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设