将 JS 对象与原型、实例类型等一起存储

Posted

技术标签:

【中文标题】将 JS 对象与原型、实例类型等一起存储【英文标题】:Storing JS objects along with prototypes, instance types etc 【发布时间】:2015-04-15 16:28:20 【问题描述】:

是否可以从本质上归档 JS 对象的状态,超出如果您要从中生成 JSON 字符串将被序列化的内容?

考虑在游戏中保存状态,并在单独的场合将其加载回window

【问题讨论】:

您有什么状态不会包含在对象的 JSON 字符串中?您需要知道进行任何(反)序列化的类型,然后原型将被继承。 您的状态是什么,如果您需要存储对象“构造函数”来保存它?我认为应该避免这种魔法。状态为普通对象 + 自定义存储/恢复功能似乎是更好的方法。它已针对 Web 应用程序进行了很好的测试(例如,请参阅 facebook's flux)。 【参考方案1】:

最简单的方法是序列化对象,然后从序列化数据中重新创建它:

function AnObject(number, string) 
  this.number = number;
  this.string = string;
  this.add = function()number++;

var initialObject = new AnObject(1, 'a');
var serialized = JSON.stringify(initalObject);
//Gives "number": 1, "string": "a"

var parsed = JSON.parse(serialized);
var recreated = new AnObject(parsed.number, parsed.string);
//Is the same as initialObject

如果你愿意,你可以序列化函数:

function serializeFunction(f) 
  var string = f.toString();
  return string.substring(string.indexOf('')+1, string.length - 1);

var func = function()alert(1);

【讨论】:

【参考方案2】:

json字符串不能包含函数、构造函数……我认为你需要做的是定义一个类,你可以在其中找到你需要的所有方法,然后你可以从你得到的json数据中实例化你的对象.这是一个简单的例子:

function Stats (options) 

     this.a = options.a;
     this.b = options.b;
     this.toString = function ()  return this.a + ' ' + this.b; ;
     this.toJSON = function ()  return  a : this.a , b : this.b ; ;
     // Methods

     return this;

在这种情况下,每当您获取 json 数据时,您只需要实例化您的对象

var stats = new Stats (JSON);
console.log(stats.toString());

【讨论】:

以上是关于将 JS 对象与原型、实例类型等一起存储的主要内容,如果未能解决你的问题,请参考以下文章

js 继承与原型链

js 原型与原型链

js 继承 原型链

js 原型链与原型

js数据类型检测

js中的原型与原型链详解