开发者社区> usher.yue> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

js解析php格式的表单到json对象

简介: /** * JsonParse * Created by usher.yue. * User: usher.yue * Date: 17/9/7 * Time: 13:50 * 心怀教育梦-烟台网格软件技术有限公司 */ class JsonConvert { ...
+关注继续查看
/**
 * JsonParse
 *  Created by usher.yue.
 * User: usher.yue
 * Date: 17/9/7
 * Time: 13:50
 * 心怀教育梦-烟台网格软件技术有限公司
 */

class JsonConvert {
    /**
     *是否可合并 去除特殊类型和 日期类型
     * @param value
     * @returns {boolean}
     * @private
     */
    _mergeable(value) {
        var stringValue = Object.prototype.toString.call(value);
        return (!!value && typeof value === 'object') && ( stringValue !== '[object RegExp]'
            && stringValue !== '[object Date]');
    };

    /**
     * 是否有必要合并
     * @param value
     * @param args
     * @returns {*}
     */
    _cloneIfNecessary(value, args) {
        var clone = args && args.clone === true;
        return (clone && _mergeable(value)) ? _deepMerge(Array.isArray(value) ? [] : {}, value, args) : value
    }

    /**
     * 数组深度合并
     * @param target
     * @param source
     * @param args
     * @returns {Array.<T>|string|Blob|ArrayBuffer}
     * @private
     */
    _arrayMerge(target, source, args) {
        var destination = target.slice();
        source.forEach(function (e, i) {
            var ctx = this;
            if (typeof destination[i] === 'undefined') {
                destination[i] = ctx._cloneIfNecessary(e, args);
            } else if (ctx._mergeable(e)) {
                destination[i] = ctx._deepMerge(target[i], e, args);
            } else if (target.indexOf(e) === -1) {
                destination.push(ctx._cloneIfNecessary(e, args));
            }
        }, this);
        return destination
    }

    /**
     *深度合并对象
     * @param target
     * @param source
     * @param args
     * @returns {{}}
     * @private
     */
    _mergeObject(target, source, args) {
        var destination = {};
        var ctx = this;
        if (this._mergeable(target)) {
            Object.keys(target).forEach(function (key) {
                destination[key] = ctx._cloneIfNecessary(target[key], args);
            });
        }
        Object.keys(source).forEach(function (key) {
            if (!ctx._mergeable(source[key]) || !target[key]) {
                destination[key] = ctx._cloneIfNecessary(source[key], args);
            } else {
                destination[key] = ctx._deepMerge(target[key], source[key], args);
            }
        });
        return destination
    }

    /**
     * 深度合并, 可自定义合并函数
     * @param target
     * @param source
     * @param args
     * @returns {*}
     * @private
     */
    _deepMerge(target, source, args) {
        var sourceIsArray = Array.isArray(source);
        var targetIsArray = Array.isArray(target);
        //默认深度合并数组
        var options = args || {arrayMerge: this._arrayMerge};
        //判断是否是一个对象避免浪费时间
        var sourceAndTargetTypesMatch = (sourceIsArray === targetIsArray);
        if (!sourceAndTargetTypesMatch) {
            return this._cloneIfNecessary(source, args)
        } else if (sourceIsArray) {
            return (options.arrayMerge || this._arrayMerge).call(this, target, source, args)
        } else {
            return this._mergeObject(target, source, args)
        }
    }

    /**
     * 必须两个参数
     * @param array
     * @param args
     * @returns {*}
     * @private
     */
    _merge(array, args) {
        if (!Array.isArray(array) || array.length < 2) {
            return false;
        }
        var ctx = this;
        //顺序执行deep merge
        return array.reduce(function (prev, next) {
            return ctx._deepMerge(prev, next, args)
        })
    };

    /**
     * json parser
     * @param obj
     * @param keyList
     * @param deepVal
     * @returns {*}
     * @private
     */
    _parseToJson(obj, keyList, deepVal) {
        let retObj = null;
        if (!keyList) {
            let re = /([_a-zA-Z]\w+|\[\]|\[[0-9]+\]|\[[_a-zA-Z]\w*\])/g;
            let combineArr = [];
            for (var key in obj) {
                retObj = {};
                //解析key
                let matchSubKey = re[Symbol.match](key);
                let indexMatch = /^\[([0-9]+)\]$/.exec(matchSubKey[1]);
                let noneIndexMatch = /^\[\]$/.exec(matchSubKey[1]);
                let objectMatch = /^\[([a-zA-Z_]\w+)\]$/.exec(matchSubKey[1]);
                if (indexMatch) {
                    retObj[matchSubKey[0]] = [];
                } else if (noneIndexMatch) {
                    retObj[matchSubKey[0]] = [];
                } else if (objectMatch) {
                    retObj[matchSubKey[0]] = {};
                }
                retObj[matchSubKey[0]] = this._parseToJson(null, matchSubKey.slice(1), obj[key]);
                combineArr.push(retObj);
            }
            return this._merge(combineArr);
        } else {
            if (keyList.length > 1) {
                let indexMatch = /^\[([0-9]+)\]$/.exec(keyList[0]);
                let noneIndexMatch = /^\[\]$/.exec(keyList[0]);
                let objectMatch = /^\[([a-zA-Z_]\w+)\]$/.exec(keyList[0]);
                if (indexMatch) {
                    retObj = [];
                    retObj[indexMatch[1]] = this._parseToJson(null, keyList.slice(1), deepVal);
                } else if (noneIndexMatch) {
                    retObj = [];
                    retObj[noneIndexMatch[1]] = [];
                    retObj.push(this._parseToJson(null, keyList.slice(1), deepVal));
                } else if (objectMatch) {
                    retObj = {};
                    retObj[objectMatch[1]] = {};
                    retObj[objectMatch[1]] = this._parseToJson(null, keyList.slice(1), deepVal);
                }
            } else if (keyList.length == 1) {
                let indexMatch = /^\[([0-9]+)\]$/.exec(keyList[0]);
                let noneIndexMatch = /^\[\]$/.exec(keyList[0]);
                let objectMatch = /^\[([a-zA-Z_]\w+)\]$/.exec(keyList[0]);
                if (indexMatch) {
                    retObj = [];
                    retObj[indexMatch[1]] = deepVal;
                } else if (noneIndexMatch) {
                    retObj = [];
                    retObj.push(deepVal);
                } else if (objectMatch) {
                    retObj[objectMatch[1]] = deepVal;
                }
            }
        }
        return retObj;
    }

    /**
     * type
     * @param o
     * @returns {*}
     * @private
     */
    _type(o) {
        return Object.prototype.toString.call(o);
    }

    /**
     * 转换
     * @param obj
     * @returns {*}
     */
    parse(obj) {
        return this._parseToJson(obj);
    }

    /**
     * 转换
     * @param obj
     * @returns {*}
     */
    stringify(obj) {
        return JSON.stringify(this._parseToJson(obj));
    }
}


var obj = {
    'data[0][classid][0]': '1000150097620084286',
    'data[0][create_time][0]': '1504692288',
    'data[0][kcid][0]': '1033150427887550927',
    'data[0][schoolid][0]': '1033144479144228284',
    'data[0][type][0]': '2',
    'data[0][uid][0]': '1034145308280458231',
    'data[0][zyid][0]': '1000150235157063544',
    'data[0][zytype][0]': 'homework-exercise',

    'data[1][classid][0]': '10001500976200842861',
    'data[1][create_time][0]': '1504692288',
    'data[1][kcid][0]': '1033150427887550927',
    'data[1][schoolid][0]': '1033144479144228284',
    'data[1][type][0]': '2',
    'data[1][uid][0]': '1034145308280458231',
    'data[1][zyid][0]': '1000150235157063544',
    'data[1][zytype][0]': 'homework-exercise',
    //
    'data[2][classid][]': '10001500976200842861',
    'data[2][create_time][]': '1504692288',
    'data[2][kcid][]': '1033150427887550927',
    'data[2][schoolid][]': '1033144479144228284',
    'data[2][type][]': '2',
    'data[2][uid][]': '1034145308280458231',
    'data[2][zyid][]': '1000150235157063544',
    'data[2][zytype][]': 'homework-exercise',

    'data[3][classid][]': '10001500976200842861',
    'data[3][create_time][]': '1504692288',
    'data[3][kcid][]': '1033150427887550927',
    'data[3][schoolid][]': '1033144479144228284',
    'data[3][type][]': '2',
    'data[3][uid][]': '1034145308280458231',
    'data[3][zyid][]': '1000150235157063544',
    'data[3][zytype][]': 'homework-exercise',

    'data[3][classid][]': '10001500976200842861',
    'data[3][create_time][]': '1504692288',
    'data[3][kcid][]': '1033150427887550927',
    'data[3][schoolid][]': '1033144479144228284',
    'data[3][type][]': '2',
    'data[3][uid][]': '1034145308280458231',
    'data[3][zyid][]': '1000150235157063544',
    'data[3][zytype][]': 'homework-exercise'
};


let json = new JsonConvert();
console.log(json.parse(obj));
console.log(json.stringify(obj))

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
常用javascript表单验证方法
//座机电话验证(支持分机) function chekeTel(tel) { var Tel = /^\d{3,4}-\d{7,8}(-\d{3,4})?$/; if (Tel.
951 0
基于H5+css+JavaScript实现动态线性渐变背景
基于H5+css+JavaScript实现动态线性渐变背景
25 0
基于H5+css+JavaScript实现全屏覆盖导航栏
基于H5+css+JavaScript实现全屏覆盖导航栏
43 0
css3结合JavaScript实现翻页幻灯片效果
CSS3+JavaScript实现翻页幻灯片效果
10 0
JavaScript实现简单区块链
用JavaScript来实现一个简单的区块链。通过实现过程,你将理解区块链是什么:区块链就是一个分布式数据库,存储结构是一个不断增长的链表,链表中包含着许多有序的记录。
1078 0
使用JavaScript实现一个俄罗斯方块
清明假期期间,闲的无聊,就做了一个小游戏玩玩,目前游戏逻辑上暂未发现bug,只不过样子稍微丑了一些-.-项目地址:https://github.com/Jiasm/tetris在线Demo:http://blog.
1436 0
JavaScript进阶【五】利用JavaScript实现动画的基本思路
版权声明:本文为博主原创文章,未经博主允许不得转载。更多学习资料请访问我爱科技论坛:www.52tech.tech https://blog.csdn.net/m0_37981569/article/details/79659313 ...
917 0
Javascript实现完美继承
javascipt 实现javascript完美继承要考虑三个方面: 第一步: 获取父构造函数体内的属性 解决方法: 通过 Father.
897 0
javascript oo实现
很久很久以前,我还是个phper,第一次接触javascript觉得好神奇。跟传统的oo类概念差别很大。记得刚毕业面试,如何在javascript里面实现class一直是很热门的面试题,当前面试百度就被问到了,当年作为一个小白只是网上随便搜搜应付了下。
615 0
+关注
usher.yue
算法相关技术专家
文章
问答
文章排行榜
最热
最新
相关电子书
更多
JS 语言在引擎级别的执行过程
立即下载
Python第五讲——关于爬虫如何做js逆向的思路
立即下载
编程语言如何演化—— 以 JS 的 private 为例
立即下载