当前位置: 首页 > news >正文

广州市企业网站建设平台网络公司名字

广州市企业网站建设平台,网络公司名字,深圳网站关键词优化,高端医疗网站建设最近俺在接触 Chrome 插件开发,需要把一个数据存放到浏览器的存储中。这个数据结构有点复杂,它包含一个 Map 和一个数组。我使用 chrome.storage.local API来存储这个数据,然后在另一个地方获取数据。保存数据的代码并没有报错,但…

最近俺在接触 Chrome 插件开发,需要把一个数据存放到浏览器的存储中。这个数据结构有点复杂,它包含一个 Map 和一个数组。我使用 chrome.storage.local API来存储这个数据,然后在另一个地方获取数据。保存数据的代码并没有报错,但是俺发现获取的时候获取结果的内容为空,这是为什么呢?

下面是我封装的保存数据和获取数据的方法:

// 要存储的数据结构
const mindDataObj = {keywordMap: new Map(),mindDataArr: []
};/*** 获取存储对象* @param {string} key 存储对象的键* @returns {Promise<Object>} 返回一个包含存储对象的 Promise*/
export async function getObject(key) {return new Promise((resolve, reject) => {chrome.storage.local.get([key], (result) => {if (chrome.runtime.lastError) {return reject(chrome.runtime.lastError)}resolve(result[key] || {})})})
}/*** 保存存储对象* @param {string} key 存储对象的键* @param {Object} obj 要保存的对象* @returns {Promise<void>} 返回一个 Promise,表示操作完成*/
export async function saveObject(key, obj) {return new Promise((resolve, reject) => {chrome.storage.local.set({ [key]: obj }, () => {if (chrome.runtime.lastError) {return reject(chrome.runtime.lastError)}resolve()})})
}

为什么会这样?

经过查找资料发现,chrome.storage.local 的存储机制只能存储和检索序列化的 JSON 对象,虽然JSON可以很好地处理对象和数组,但对于MapSet等ES6中引入的复杂数据结构,JSON是无法直接序列化和反序列化的。因此,尽管你可能没有在保存数据时遇到错误,但在尝试读取非JSON兼容类型的数据时,这些数据将因无法被正确序列化而丢失。

解决方案

总之一句话:chrome.storage.local 只能存储 JSON 兼容的数据类型(如对象、数组、字符串、数字等),MapSet 需要转换为对象或数组才能正确存储。在这里,我们通过 chrome.storage.local 存储时需要先进行序列化处理,而在读取时需要进行反序列化处理。

步骤1: 序列化和反序列化Map对象

我们先增加两个方法做序列化的处理,serializeMapdeserializeMap 方法用于将 Map 对象转换为数组,从而可以存储在 chrome.storage.local 中,并在读取时将其转换回 Map 对象。

/*** 序列化Map对象* @param {Map} map 要序列化的Map对象* @returns {Object} 序列化后的对象*/
function serializeMap(map) {return Array.from(map.entries());
}/*** 反序列化Map对象* @param {Array} entries 序列化后的对象* @returns {Map} 反序列化后的Map对象*/
function deserializeMap(entries) {return new Map(entries);
}

步骤2: 存储和读取数据

然后再增加操作数据的方法,saveMindDatagetMindData 方法用于保存和获取 mindDataObj 格式的数据,包括序列化和反序列化步骤。

/*** 保存mindDataObj格式的数据* @param {string} key 存储对象的键* @param {Object} initMindDataObj 要保存的对象* @returns {Promise<void>} 返回一个 Promise,表示操作完成*/
export async function saveMindData(key, mindDataObj) {const serializedData = {keywordMap: serializeMap(mindDataObj.keywordMap),mindDataArr: mindDataObj.mindDataArr};await saveObject(key, serializedData);
}/*** 获取mindDataObj格式的数据* @param {string} key 存储对象的键* @returns {Promise<Object>} 返回一个包含mindDataObj格式数据的 Promise*/
export async function getMindData(key) {const serializedData = await getObject(key);const mindDataObj = {keywordMap: deserializeMap(serializedData.keywordMap || []),mindDataArr: serializedData.mindDataArr || []};return mindDataObj;
}
http://www.skylitedrivein.com/news/683.html

相关文章:

  • 做色情诱导网站苏州网站建设
  • wordpress获取帖子标签性价比高seo排名优化的
  • 用手机制作网站网络推广渠道
  • 音乐网站建设的目的网络推广的方法有多选题
  • 怎么去找做网站的企业网站的作用
  • 百度网站链接提交今日热搜第一名
  • 大连网站建设培训班软文营销经典案例
  • 做韩服的视频网站移动排名提升软件
  • cookie做网站登录seo会被取代吗
  • 网站开发建设挣钱吗网络推广策划方案模板
  • 好的网站建站公司优化大师班级
  • 定制化网站开发公司查询网站流量
  • 米各庄网站建设东莞seo建站优化工具
  • 深圳服装网站建设制作开发安装百度到手机桌面
  • 中国五大门户网站免费ip地址网站
  • 做网站费用会计科目舆情分析
  • 阿里云空间部署网站吗seo优化是什么意思
  • 天津市住房和城乡建设委员会官方网站福建百度代理公司
  • 华为云服务器怎么做网站b2b网站免费推广
  • 企业公众号如何开通seo外包公司优化
  • 专业网站建设最新报价发布软文
  • 宁晋网站建设seo图片优化的方法
  • 微网站开发技术太原网站快速排名优化
  • 永州做网站的公司百度网站首页提交入口
  • 江西网站开发多少钱天津疫情最新消息
  • wordpress标签tag文章厦门seo排名收费
  • 深圳p2p网站开发长春网站制作
  • 手机app网站开发宁德市教育局官网
  • 一个网站开发的假设社交网络推广方法有哪些
  • 企点qqseo优化服务公司