0

0

如何用 JSON.parse(JSON.stringify()) 完整保存并恢复包含 ES5 和 ES6 函数的对象?

心靈之曲

心靈之曲

发布时间:2025-02-24 08:54:14

|

528人浏览过

|

来源于php中文网

原创

如何用 json.parse(json.stringify()) 完整保存并恢复包含 es5 和 es6 函数的对象?

在数据库中存储和恢复包含 ES5 和 ES6 函数的对象

许多应用场景需要将包含函数的对象序列化为字符串,存储到数据库中,并在需要时再反序列化回对象。 然而,标准的 JSON.stringify() 方法无法处理函数。本文介绍一种方法,能够完整保存和恢复包含 ES5 和 ES6 函数的对象。

解决方案:

可以使用自定义的序列化和反序列化函数来实现这一目标。这些函数会将函数转换为可序列化的字符串表示,并在反序列化时将其转换回函数。 这需要一个约定来标识和处理函数字符串。

示例代码:

Mapify
Mapify

Mapify是由Xmind推出的AI思维导图生成工具,原名ChatMind

下载

以下示例展示了如何使用自定义函数 toJsonparseJson 来实现这一功能:

const toJson = (obj) => {
  const cache = new Map();
  return JSON.stringify(obj, (key, value) => {
    if (typeof value === 'function') {
      const funcString = value.toString();
      if (!cache.has(funcString)) {
        const id = cache.size + 1;
        cache.set(funcString, `__func_${id}__`);
      }
      return cache.get(funcString);
    }
    return value;
  });
};

const parseJson = (jsonString) => {
  const cache = new Map();
  return JSON.parse(jsonString, (key, value) => {
    if (typeof value === 'string' && value.startsWith('__func_')) {
      const id = parseInt(value.substring(7), 10);
      const funcString = cache.get(id);
      if (funcString) {
        return eval(`(${funcString})`); // 使用eval,请注意安全风险
      }
    }
    return value;
  });
};


const originalObject = {
  name: 'John Doe',
  age: 25,
  onGetName: function() {
    console.log(this.name);
  },
  onGetAge: () => {
    console.log(this.age);
  }
};

const jsonString = toJson(originalObject);
// ... 保存 jsonString 到数据库 ...

// ... 从数据库读取 jsonString ...
const retrievedJsonString = jsonString;

const retrievedObject = parseJson(retrievedJsonString);

retrievedObject.onGetName(); // 输出:John Doe
retrievedObject.onGetAge(); // 输出:25

说明:

  • toJson 函数使用 JSON.stringify 和一个自定义的 replacer 函数。 replacer 函数将函数转换为 __func_id__ 的形式,并将其存储在 cache 中。
  • parseJson 函数使用 JSON.parse 和一个自定义的 reviver 函数。 reviver 函数将 __func_id__ 转换为函数。 请注意,这里使用了 eval(),这在处理来自不受信任来源的数据时存在安全风险。 在生产环境中,应该考虑更安全的替代方案,例如使用一个更严格的函数解析器或避免直接使用 eval()

此方法提供了一种相对简单的解决方案,但务必谨慎处理 eval() 的安全风险。 对于大型项目或安全性要求较高的应用,建议探索更健壮和安全的序列化/反序列化库。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

529

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

96

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2025.12.24

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.08.03

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号