JavaScript 的json源码

// it will specify the number of spaces to indent at each

// level. If it is a string (such as “\t” or " "),

// it contains the characters used to indent at each level.

// This method produces a JSON text from a JavaScript value.

// When an object value is found, if the object contains a toJSON

// method, its toJSON method will be called and the result will be

// stringified. A toJSON method does not serialize: it returns the

// value represented by the name/value pair that should be serialized,

// or undefined if nothing should be serialized. The toJSON method

// will be passed the key associated with the value, and this will be

// bound to the value.

// For example, this would serialize Dates as ISO strings.

// Date.prototype.toJSON = function (key) {

// function f(n) {

// // Format integers to have at least two digits.

// return (n < 10)

// ? “0” + n

// : n;

// }

// return this.getUTCFullYear() + “-” +

// f(this.getUTCMonth() + 1) + “-” +

// f(this.getUTCDate()) + “T” +

// f(this.getUTCHours()) + “:” +

// f(this.getUTCMinutes()) + “:” +

// f(this.getUTCSeconds()) + “Z”;

// };

// You can provide an optional replacer method. It will be passed the

// key and value of each member, with this bound to the containing

// object. The value that is returned from your method will be

// serialized. If your method returns undefined, then the member will

// be excluded from the serialization.

// If the replacer parameter is an array of strings, then it will be

// used to select the members to be serialized. It filters the results

// such that only members with keys listed in the replacer array are

// stringified.

// Values that do not have JSON representations, such as undefined or

// functions, will not be serialized. Such values in objects will be

// dropped; in arrays they will be replaced with null. You can use

// a replacer function to replace those with JSON values.

// JSON.stringify(undefined) returns undefined.

// The optional space parameter produces a stringification of the

// value that is filled with line breaks and indentation to make it

// easier to read.

// If the space parameter is a non-empty string, then that string will

// be used for indentation. If the space parameter is a number, then

// the indentation will be that many spaces.

// Example:

// text = JSON.stringify([“e”, {pluribus: “unum”}]);

// // text is ‘[“e”,{“pluribus”:“unum”}]’

// text = JSON.stringify([“e”, {pluribus: “unum”}], null, “\t”);

// // text is ‘[\n\t"e",\n\t{\n\t\t"pluribus": “unum”\n\t}\n]’

// text = JSON.stringify([new Date()], function (key, value) {

// return this[key] instanceof Date

// ? “Date(” + this[key] + “)”

// : value;

// });

// // text is ‘[“Date(—current time—)”]’

// JSON.parse(text, reviver)

// This method parses a JSON text to produce an object or array.

// It can throw a SyntaxError exception.

// The optional reviver parameter is a function that can filter and

// transform the results. It receives each of the keys and values,

// and its return value is used instead of the original value.

// If it returns what it received, then the structure is not modified.

// If it returns undefined then the member is deleted.

// Example:

// // Parse the text. Values that look like ISO date strings will

// // be converted to Date objects.

// myData = JSON.parse(text, function (key, value) {

// var a;

// if (typeof value === “string”) {

// a =

// /^(\d{4})-(\d{2})-(\d{2})T(\d{2})😦\d{2})😦\d{2}(?:.\d*)?)Z$/.exec(value);

// if (a) {

// return new Date(Date.UTC(+a[1], +a[2] - 1, +a[3], +a[4],

// +a[5], +a[6]));

// }

// }

// return value;

// });

// myData = JSON.parse(‘[“Date(09/09/2001)”]’, function (key, value) {

// var d;

// if (typeof value === “string” &&

// value.slice(0, 5) === “Date(” &&

// value.slice(-1) === “)”) {

// d = new Date(value.slice(5, -1));

// if (d) {

// return d;

// }

// }

// return value;

// });

// This is a reference implementation. You are free to copy, modify, or

// redistribute.

/*jslint

eval, for, this

*/

/*property

JSON, apply, call, charCodeAt, getUTCDate, getUTCFullYear, getUTCHours,

getUTCMinutes, getUTCMonth, getUTCSeconds, hasOwnProperty, join,

lastIndex, length, parse, prototype, push, replace, slice, stringify,

test, toJSON, toString, valueOf

*/

// Create a JSON object only if one does not already exist. We create the

// methods in a closure to avoid creating global variables.

if (typeof JSON !== “object”) {

JSON = {};

}

(function () {

“use strict”;

var rx_one = /1*$/;

var rx_two = /\(?:["\/bfnrt]|u[0-9a-fA-F]{4})/g;

var rx_three = /“[^”\\n\r]"|true|false|null|-?\d+(?:.\d)?(?:[eE][+-]?\d+)?/g;

var rx_four = /(?:^|:|,)(?:\s*[)+/g;

var rx_escapable = /[\"\u0000-\u001f\u007f-\u009f\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g;

var rx_dangerous = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g;

function f(n) {

// Format integers to have at least two digits.

return n < 10

? “0” + n
n;

}

function this_value() {

return this.valueOf();

}

if (typeof Date.prototype.toJSON !== “function”) {

Date.prototype.toJSON = function () {

return isFinite(this.valueOf())

? this.getUTCFullYear() + “-” +

f(this.getUTCMonth() + 1) + “-” +

f(this.getUTCDate()) + “T” +

f(this.getUTCHours()) + “:” +

f(this.getUTCMinutes()) + “:” +

f(this.getUTCSeconds()) + “Z”
null;

};

Boolean.prototype.toJSON = this_value;

Number.prototype.toJSON = this_value;

String.prototype.toJSON = this_value;

}

var gap;

var indent;

var meta;

var rep;

function quote(string) {

// If the string contains no control characters, no quote characters, and no

// backslash characters, then we can safely slap some quotes around it.

// Otherwise we must also replace the offending characters with safe escape

// sequences.

rx_escapable.lastIndex = 0;

return rx_escapable.test(string)

? “”" + string.replace(rx_escapable, function (a) {

var c = meta[a];

return typeof c === “string”

? c
“\u” + (“0000” + a.charCodeAt(0).toString(16)).slice(-4);
}) + “”"
“”" + string + “”";

}

function str(key, holder) {

// Produce a string from holder[key].

var i; // The loop counter.

var k; // The member key.

var v; // The member value.

var length;

var mind = gap;

var partial;

var value = holder[key];

// If the value has a toJSON method, call it to obtain a replacement value.

if (value && typeof value === “object” &&

typeof value.toJSON === “function”) {

value = value.toJSON(key);

}

// If we were called with a replacer function, then call the replacer to

// obtain a replacement value.

if (typeof rep === “function”) {

value = rep.call(holder, key, value);

}

// What happens next depends on the value’s type.

switch (typeof value) {

case “string”:

return quote(value);

case “number”:

// JSON numbers must be finite. Encode non-finite numbers as null.

return isFinite(value)

? String(value)
“null”;

case “boolean”:

case “null”:

// If the value is a boolean or null, convert it to a string. Note:

// typeof null does not produce “null”. The case is included here in

// the remote chance that this gets fixed someday.

return String(value);

// If the type is “object”, we might be dealing with an object or an array or

// null.

case “object”:

// Due to a specification blunder in ECMAScript, typeof null is “object”,

// so watch out for that case.

if (!value) {

return “null”;

}

// Make an array to hold the partial results of stringifying this object value.

gap += indent;

partial = [];

// Is the value an array?

if (Object.prototype.toString.apply(value) === “[object Array]”) {

// The value is an array. Stringify every element. Use null as a placeholder

// for non-JSON values.

length = value.length;

for (i = 0; i < length; i += 1) {

partial[i] = str(i, value) || “null”;

}

// Join all of the elements together, separated with commas, and wrap them in

// brackets.

v = partial.length === 0

? “[]”
gap
? “[\n” + gap + partial.join(“,\n” + gap) + “\n” + mind + “]”
“[” + partial.join(“,”) + “]”;

gap = mind;

return v;

}

// If the replacer is an array, use it to select the members to be stringified.

if (rep && typeof rep === “object”) {

length = rep.length;

for (i = 0; i < length; i += 1) {

if (typeof rep[i] === “string”) {

k = rep[i];

v = str(k, value);

if (v) {

partial.push(quote(k) + (

gap

? ": "
“:”

) + v);

}

}

}

} else {

// Otherwise, iterate through all of the keys in the object.

for (k in value) {

if (Object.prototype.hasOwnProperty.call(value, k)) {

v = str(k, value);

if (v) {

partial.push(quote(k) + (

gap

? ": "
“:”

) + v);

}

}

}

}

// Join all of the member texts together, separated with commas,

// and wrap them in braces.

v = partial.length === 0

? “{}”

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
v = partial.length === 0

? “{}”

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-Eo7KdoyO-1715466086934)]

[外链图片转存中…(img-AcwPhQTt-1715466086935)]

[外链图片转存中…(img-Dwu6Uy9U-1715466086935)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!


  1. ],:{}\s ↩︎

  • 21
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
zypalyer json源码是一个用于解析和生成JSON数据的源代码库。JSONJavaScript Object Notation)是一种轻量级的数据交换格式,常用于前后端数据传输和存储。zypalyer json源码提供了一些方法和工具,方便处理JSON数据。 源码中包含了一些核心类和函数,用于解析和生成JSON数据。其中,主要有以下几个关键部分: 1. JSON解析器:该解析器负责将JSON字符串解析为相应的数据结构,如对象、数组、字符串、数字等。它会递归地遍历JSON字符串,并根据符号和格式将其转换为对应的数据类型。 2. JSON生成器:这部分代码负责将数据结构转换为JSON字符串。它会根据数据类型和规则,递归地遍历数据结构,并将其转换为符合JSON格式的字符串。 3. JSON类型转换:这部分代码提供了一些方法,用于在JSON数据和其他编程语言数据类型之间进行转换。例如,可以将JSON字符串转换为对象,或将对象转换为JSON字符串。 4. 异常处理:为了提高代码的健壮性,源码中还包含了一些异常处理机制。当遇到无效的JSON字符串或其他错误时,它会抛出相应的异常,以便开发者能够及时发现并处理问题。 总体而言,zypalyer json源码是一个功能齐全、易于使用的JSON解析和生成工具。它能够方便地处理JSON数据,帮助开发者在各种场景下进行快速、高效地数据交互和存储。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值