首页 前端知识 JavaScript 的json源码,限时发布

JavaScript 的json源码,限时发布

2024-09-06 00:09:23 前端知识 前端哥 215 128 我要收藏

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

? “{}”
gap
? “{\n” + gap + partial.join(“,\n” + gap) + “\n” + mind + “}”
“{” + partial.join(“,”) + “}”;

gap = mind;

return v;

}

}

// If the JSON object does not yet have a stringify method, give it one.

if (typeof JSON.stringify !== “function”) {

meta = { // table of character substitutions

“\b”: “\b”,

“\t”: “\t”,

“\n”: “\n”,

“\f”: “\f”,

“\r”: “\r”,

“”“: “\””,

“\”: “\\”

};

JSON.stringify = function (value, replacer, space) {

// The stringify method takes a value and an optional replacer, and an optional

// space parameter, and returns a JSON text. The replacer can be a function

// that can replace values, or an array of strings that will select the keys.

// A default replacer method can be provided. Use of the space parameter can

// produce text that is more easily readable.

var i;

gap = “”;

indent = “”;

// If the space parameter is a number, make an indent string containing that

// many spaces.

if (typeof space === “number”) {

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

indent += " ";

}

// If the space parameter is a string, it will be used as the indent string.

} else if (typeof space === “string”) {

indent = space;

}

// If there is a replacer, it must be a function or an array.

// Otherwise, throw an error.

rep = replacer;

if (replacer && typeof replacer !== “function” &&

(typeof replacer !== “object” ||

typeof replacer.length !== “number”)) {

throw new Error(“JSON.stringify”);

}

// Make a fake root object containing our value under the key of “”.

// Return the result of stringifying the value.

return str(“”, {“”: value});

};

}

// If the JSON object does not yet have a parse method, give it one.

if (typeof JSON.parse !== “function”) {

JSON.parse = function (text, reviver) {

// The parse method takes a text and an optional reviver function, and returns

// a JavaScript value if the text is a valid JSON text.

var j;

function walk(holder, key) {

// The walk method is used to recursively walk the resulting structure so

// that modifications can be made.

var k;

var v;

var value = holder[key];

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

for (k in value) {

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

v = walk(value, k);

if (v !== undefined) {

value[k] = v;

} else {

delete value[k];

}

}

}

}

return reviver.call(holder, key, value);

}

// Parsing happens in four stages. In the first stage, we replace certain

// Unicode characters with escape sequences. JavaScript handles many characters

// incorrectly, either silently deleting them, or treating them as line endings.

text = String(text);

rx_dangerous.lastIndex = 0;

if (rx_dangerous.test(text)) {

text = text.replace(rx_dangerous, function (a) {

return “\u” +

(“0000” + a.charCodeAt(0).toString(16)).slice(-4);

});

}

// In the second stage, we run the text against regular expressions that look

// for non-JSON patterns. We are especially concerned with “()” and “new”

// because they can cause invocation, and “=” because it can cause mutation.

// But just to be safe, we want to reject all unexpected forms.

// We split the second stage into 4 regexp operations in order to work around

// crippling inefficiencies in IE’s and Safari’s regexp engines. First we

// replace the JSON backslash pairs with “@” (a non-JSON character). Second, we

// replace all simple value tokens with “]” characters. Third, we delete all

// open brackets that follow a colon or comma or that begin the text. Finally,

// we look to see that the remaining characters are only whitespace or “]” or

// “,” or “:” or “{” or “}”. If that is so, then the text is safe for eval.

if (

rx_one.test(

text

.replace(rx_two, “@”)

.replace(rx_three, “]”)

.replace(rx_four, “”)

)

) {

// In the third stage we use the eval function to compile the text into a

// JavaScript structure. The “{” operator is subject to a syntactic ambiguity

// in JavaScript: it can begin a block or an object literal. We wrap the text

// in parens to eliminate the ambiguity.

j = eval(“(” + text + “)”);

// In the optional fourth stage, we recursively walk the new structure, passing

// each name/value pair to a reviver function for possible transformation.

return (typeof reviver === “function”)

? walk({“”: j}, “”)
j;

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

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

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

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

JavaScript 和 ES6

在这个过程你会发现,有很多 JS 知识点你并不能更好的理解为什么这么设计,以及这样设计的好处是什么,这就逼着让你去学习这单个知识点的来龙去脉,去哪学?第一,书籍,我知道你不喜欢看,我最近通过刷大厂面试题整理了一份前端核心知识笔记,比较书籍更精简,一句废话都没有,这份笔记也让我通过跳槽从8k涨成20k。

JavaScript部分截图

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

个过程你会发现,有很多 JS 知识点你并不能更好的理解为什么这么设计,以及这样设计的好处是什么,这就逼着让你去学习这单个知识点的来龙去脉,去哪学?第一,书籍,我知道你不喜欢看,我最近通过刷大厂面试题整理了一份前端核心知识笔记,比较书籍更精简,一句废话都没有,这份笔记也让我通过跳槽从8k涨成20k。

JavaScript部分截图

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

转载请注明出处或者链接地址:https://www.qianduange.cn//article/17768.html
标签
评论
发布的文章

安装Nodejs后,npm无法使用

2024-11-30 11:11:38

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!