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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: /** * 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))
目录
相关文章
|
28天前
|
JavaScript 前端开发
Moment.js与其他处理时间戳格式差异的JavaScript库相比有什么优势?
Moment.js与其他处理时间戳格式差异的JavaScript库相比有什么优势?
|
29天前
|
算法 开发者
Moment.js库是如何处理不同浏览器的时间戳格式差异的?
总的来说,Moment.js 通过一系列的技术手段和策略,有效地处理了不同浏览器的时间戳格式差异,为开发者提供了一个稳定、可靠且易于使用的时间处理工具。
35 1
|
1月前
ractive.js联系表单动画效果源码
一款ractive.js联系表单动画效果,很有创意的发送邮件、联系内容等表单,基于ractive.js实现的动画效果,以发送信件的方式。
24 1
|
1月前
|
JSON JavaScript Java
对比JSON和Hessian2的序列化格式
通过以上对比分析,希望能够帮助开发者在不同场景下选择最适合的序列化格式,提高系统的整体性能和可维护性。
43 3
|
1月前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
46 3
|
1月前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
1月前
|
JSON Java 数据格式
springboot中表字段映射中设置JSON格式字段映射
springboot中表字段映射中设置JSON格式字段映射
121 1
|
1月前
|
JSON 人工智能 算法
探索LLM推理全阶段的JSON格式输出限制方法
文章详细讨论了如何确保大型语言模型(LLMs)输出结构化的JSON格式,这对于提高数据处理的自动化程度和系统的互操作性至关重要。
|
1月前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
71 2
下一篇
DataWorks