关于sdk:SDK-兼容-JSON

41次阅读

共计 1755 个字符,预计需要花费 5 分钟才能阅读完成。

最近在集成融云 SDK,于是看了下融云的 SDK 源码,发现源码中有一段针对 JSON 的适配,因为针对 IE9 以下不反对 JSON 对象的解决形式,在此分享下

1、长处: 除中文外的字符都会转为 Unicode。

2、毛病:JSON.parse() 应用 eval 进行转换的,这个办法不是很平安,还看到人介绍用 new Function,然而没有测试,这里临时标记下,有空测试下。

if (!window[“JSON”]) {
window[“JSON”] = (function () {
function JSON() {
}
JSON.parse = function (sJSON) {
return eval(‘(‘ + sJSON + ‘)’);
};
JSON.stringify = function (value) {
return this.str(“”, { “”: value});
};
JSON.str = function (key, holder) {
var i, k, v, length, mind = “”, partial, value = holder[key], me = this;
if (value && typeof value === “object” && typeof value.toJSON === “function”) {
value = value.toJSON(key);
}
switch (typeof value) {
case “string”:
return me.quote(value);
case “number”:
return isFinite(value) ? String(value) : “null”;
case “boolean”:
case “null”:
return String(value);
case “object”:
if (!value) {
return “null”;
}
partial = [];
if (Object.prototype.toString.apply(value) === “[object Array]”) {
length = value.length;
for (i = 0; i < length; i += 1) {
partial[i] = me.str(i, value) || “null”;
}
v = partial.length === 0 ? “[]” : “[” + partial.join(“,”) + “]”;
return v;
}
for (k in value) {
if (Object.prototype.hasOwnProperty.call(value, k)) {
v = me.str(k, value);
if (v) {
partial.push(me.quote(k) + “:” + v);
}
}
}
v = partial.length === 0 ? “{}” : “{” + partial.join(“,”) + “}”;
return v;
}
};
JSON.quote = function (string) {
var me = this;
me.rx_escapable.lastIndex = 0;
return me.rx_escapable.test(string) ? ‘”‘ + string.replace(me.rx_escapable, function (a) {
var c = me.meta[a];
return typeof c === “string” ? c : “u” + (“0000” + a.charCodeAt(0).toString(16)).slice(-4);
}) + ‘”‘ : ‘”‘ + string + ‘”‘;
};
JSON.rx_escapable = new RegExp(‘[“”u0000-u001fu007f-u009fu00adu0600-u0604u070fu17b4u17b5u200c-u200fu2028-u202fu2060-u206fufeffufff0-uffff]’, “g”);
JSON.meta = {
“b”: “b”,
”   “: “t”,
“n”: “n”,
“f”: “f”,
“r”: “r”,
‘”‘: ‘”‘,
“””: “””,
“”: “”
};
return JSON;
})();
}

看到这段代码,感觉融云 SDK 在兼容性上还是有解决的,又在 IE7 下做了测试,果然能够稳固运行(这年头还有 IE7,是不是很神奇)

融云官网:https://www.rongcloud.cn

融云文档:https://docs.rongcloud.cn/v4

正文完
 0