原生js实现JSON.parse()和JSON.stringify()

- 首先JSON.stringify()是将js对象转换为JSON形式

实现思路:

通过递归调用,来实现对转换对象Object的深层value进行遍历,利用array的join实现最终字符串拼接

function myJsonStringify(obj) {
        let type = typeof obj;
        if (type !== "object" || type === null) {
            if (/string|undefined|function/.test(type)) {
                obj = '"' + obj + '"';
            }
            return String(obj);
        } else {
            let json = [],
                arr = (obj && obj.constructor === Array);

            for (let k in obj) {
                let v = obj[k];
                let type = typeof v;

                if (/string|undefined|function/.test(type)) {
                    v = '"' + v + '"';
                } else if (type === "object") {
                    v = myJsonStringify(v);
                }

                json.push((arr ? "" : '"' + k + '":') + String(v));
            }
            return (arr ? "[" : "{") + String(json) + (arr ? "]" : "}")
        }
    }

一个较为完整版的实现:

(function(NS){
var simpleTypes=["number","boolean","undefined","string","function"]
function stringify(object){
    var type=typeof object
    if(indexOf(simpleTypes,type)>-1){
        return parseSimpleObject(object);
    }
    if(object instanceof Array){
        var len=object.length;
        var resArr=[];
        for(var i=0;i<len;i++){
            var itemType=typeof object[i];
            if(indexOf(simpleTypes,itemType)>-1){
                if(itemType!="undefined"){
                    resArr.push(parseSimpleObject(object[i]));
                }
                else{
                    resArr.push('null')
                }
            }
            else{
                resArr.push(stringify(object[i]))
            }
        }
        return "["+resArr.join(",")+ "]"
    }
    if(object instanceof Object){
        if(object==null){
            return "null"
        }
        var resArr=[]
        for(var name in object){
            var itemType=typeof object[name];
            if(indexOf(simpleTypes,itemType)>-1){
                if(itemType!='undefined'){
                    resArr.push("\"" + name + "\":" + parseSimpleObject(object[name]))
                }
            }
            else{
                resArr.push("\"" + name +"\":" +stringify(object[name]))
            }
        }
        return "{" +resArr.join(",") +"}"
    }
}
function parseSimpleObject(object){
    var type=typeof object;
    if(type=="string"||type=="function"){
        return "\"" + object.toString().replace("\"","\\\"") + "\""
    }
    if(type=="number"||type=="boolean"){
        return object.toString()
    }
    if(type=="undefined"){
        return  "undefined"
    }
    return  "\"" +object.toString().replace("\"","\\\"") +"\""
}
function indexOf(arr,val){
    for(var i=0;i<arr.length;i++){
        if(arr[i]===val){
            return i;
        }
    }
    return -1
}
NS.stringify=function(object,isEncodeZh){
    var res=stringify(object)
    if(isEncodeZh){
        var encodeRes="";
        for(var i=0;i<res.length;i++){
            if(res.charCodeAt(i)<Oxff){
                encodeRes+=res[i]
            }
            else{
                encodeRes+="\\u"+res.charCodeAt(i).toString(16);
            }
        }
        res=encodeRes
    }
    return res;
}
})(window);

JSON.parse()是将JSON对象转换为js对象

实现方式:(2种)

eval()

var json='{"a":"1","b":2}'
 var obj=eval("("+json+")");

直接调用eval,会产生xss漏洞。

利用new Function()

第一种eval的方法,相当于无脑把JSON字符串塞进去,eval和Function都有着动态编译js代码的作用

var func=new Function(arg1,arg2,...,functionBody)
var jsonStr='{"age":20,"name":"jack"}'
var json=(new Function('return'+jsonStr))()

 

posted on 2019-06-06 19:46  袁233  阅读(2562)  评论(0编辑  收藏  举报

导航