当前位置: 首页 > 面试题库 >

toJSON()和JSON.Stringify()之间的区别

莫宝
2023-03-14
问题内容

如果您需要读取或克隆模型的所有数据属性,请使用其toJSON()方法。此方法以对象的形式返回属性的副本(尽管名称不同,但不是JSON字符串)。(当JSON.stringify()通过toJSON()方法传递给对象时,它将对toJSON()的返回值而不是原始对象进行字符串化。上一节中的示例在调用JSON.stringify时利用了此功能。
()记录模型实例。)

http://addyosmani.github.io/backbone-fundamentals/#backbone-
basics

谁能告诉我,这两种方式之间的差异representing an objectJSON符号。我只是感到困惑,无论是实现相同还是不同。


问题答案:

从精美的手册中:

toJSON行为

如果要被字符串化的对象具有一个名为toJSON的属性,其值是一个函数,那么该toJSON方法将自定义JSON字符串化行为:代替被序列化的对象,toJSON方法被调用时返回的值将被序列化,而不是被序列化的对象。

这就是为什么Backbone使用该toJSON方法进行序列化并给定名为的模型实例的原因m,您可以这样说:

var string = JSON.stringify(m);

并从中获取属性,m而不是从服务器中忽略一堆噪音。

也就是说,主要区别在于toJSON产生的值(数字,布尔值,对象等)将转换为JSON字符串,而JSON.stringify始终产生一个字符串。

该默认骨干toJSON仅仅是这个(适用机型):

return _.clone(this.attributes);

这样就m.toJSON()为您提供了模型属性的 浅表
副本。如果有数组或对象作为属性值,那么您将结束意外的引用共享。注意,Backbone.Model#clone也遭受这个问题。

如果您想安全地克隆模型的数据,则可以将其发送出去JSON.stringify,然后JSON.parse获得深层副本:

var data         = JSON.parse(JSON.stringify(model_instance));
var cloned_model = new M(data);

model_instance您的骨干模型实例在哪里M



 类似资料:
  • 问题内容: 我对于何时使用这两种解析方法感到困惑。 在回显我的json_encoded数据并通过ajax将其检索回去之后,我常常会困惑何时应该使用 JSON.stringify 和 JSON.parse 。 我得到我 的console.log 字符串化时解析和JavaScript对象时。 问题答案: 将JavaScript对象转换为JSON文本并将该JSON文本存储在字符串中,例如: 将JSON文

  • 问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:

  • 问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。

  • 问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然

  • 问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra