JSON

JSON.stringify 函数 (JavaScript)讲解

字号+ 作者:H5之家 来源:H5之家 2017-05-19 14:06 我要评论( )

JSON.stringify 函数 (JavaScript)讲解

JSON.stringify 函数 (JavaScript)讲解

将 JavaScript 值转换为 JavaScript 对象表示法 (Json) 字符串。

语法:JSON.stringify(value [, replacer] [, space])参数:

 value:必需。 要转换的 JavaScript 值(通常为对象或数组)。
 replacer:可选。 用于转换结果的函数或数组。

 如果 replacer 为函数,则 JSON.stringify 将调用该函数,并传入每个成员的键和值。 使用返回值而不是原始值。 如果此函数返回 undefined,则排除成员。 根对象的键是一个空字符串:""。

 如果 replacer 是一个数组,则仅转换该数组中具有键值的成员。 成员的转换顺序与键在数组中的顺序一样。 当 value 参数也为数组时,将忽略 replacer 数组。

 space:可选。 向返回值 JSON 文本添加缩进、空格和换行符以使其更易于读取。

如果省略 space,则将生成返回值文本,而没有任何额外空格。

如果 space 是一个数字,则返回值文本在每个级别缩进指定数目的空格。 如果 space 大于 10,则文本缩进 10 个空格。

如果 space 是一个非空字符串(例如“\t”),则返回值文本在每个级别中缩进字符串中的字符。

如果 space 是长度大于 10 个字符的字符串,则使用前 10 个字符。

返回值:

一个包含 JSON 文本的字符串。

异常:

Exception Condition。

执行顺序:

在序列化过程中,如果 value 参数对应有 toJSON 方法,则 JSON.stringify 将首先调用 toJSON 方法。 如果该方法不存在,则使用原始值。 接下来,如果提供 replacer 参数,则该值(原始值或 toJSON 返回值)将替换为 replacer 参数的返回值。 最后,根据可选 space 参数向该值添加空格以生成最终的 JSON 文本。

此示例使用JSON.stringify 将 contact 对象转换为 JSON 文本。定义 memberfilter 数组以便只转换 surname 和 phone 成员。省略 firstname成员。

var contact = new Object(); contact.firstname = "Jesper"; contact.surname = "Aaberg"; contact.phone = ["555-0100", "555-0120"]; var memberfilter = new Array(); memberfilter[0] = "surname"; memberfilter[1] = "phone"; var jsonText = JSON.stringify(contact, memberfilter, "\t"); document.write(jsonText); // Output: // { "surname": "Aaberg", "phone": [ "555-0100", "555-0120" ] } 此示例将 JSON.stringify 与一个数组一起使用。

replaceToUpper函数将数组中的每个字符串转换为大写形式。

var continents = new Array(); continents[0] = "Europe"; continents[1] = "Asia"; continents[2] = "Australia"; continents[3] = "Antarctica"; continents[4] = "North America"; continents[5] = "South America"; continents[6] = "Africa"; var jsonText = JSON.stringify(continents, replaceToUpper); function replaceToUpper(key, value) { return value.toString().toUpperCase(); } //Output: // "EUROPE,ASIA,AUSTRALIA,ANTARCTICA,NORTH AMERICA,SOUTH AMERICA,AFRICA"

此示例使用 toJSON 方法将字符串值转换为大写形式。

var contact = new Object(); contact.firstname = "Jesper"; contact.surname = "Aaberg"; contact.phone = ["555-0100", "555-0120"]; contact.toJSON = function(key) { var replacement = new Object(); for (var val in this) { if (typeof (this[val]) === 'string') replacement[val] = this[val].toUpperCase(); else replacement[val] = this[val] } return replacement; }; var jsonText = JSON.stringify(contact); document.write(jsonText); // Output: {"firstname":"JESPER","surname":"AABERG","phone":["555-0100","555-0120"]} '{"firstname":"JESPER","surname":"AABERG","phone":["555-0100","555-0120"]}'

PS:在以上文档模式中受到支持:Internet Explorer 8 标准模式、Internet Explorer 9 标准模式、Internet Explorer 10 标准模式、Internet Explorer 11 标准模式。此外,也在应用商店应用(Windows 8 和 Windows Phone 8.1)中受支持。

本文主题

Json.stringify() json

如果本文对你有帮助,那么请你赞助我,让我更有激情的写下去,帮助更多的人。

版权所属:SO JSON在线解析

原文地址:

转载时必须以链接形式注明原始出处及本声明。

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • js 获取Json对象数据长度的例子

    js 获取Json对象数据长度的例子

    2017-05-19 08:02

  • Android读取本地json文件的方法(解决显示乱码问题)

    Android读取本地json文件的方法(解决显示乱码问题)

    2017-05-18 10:00

  • 浅谈 JSON.stringify 方法 - 乱码.

    浅谈 JSON.stringify 方法 - 乱码.

    2017-05-17 18:02

  • 从 XML 生成可与 Ajax 共同使用的 JSON

    从 XML 生成可与 Ajax 共同使用的 JSON

    2017-05-17 18:00

网友点评