首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从单个数组创建多个数组?

如何从单个数组创建多个数组?
EN

Stack Overflow用户
提问于 2022-04-27 09:22:50
回答 1查看 90关注 0票数 0

我在我的控制台中获得如下表单数据:

代码语言:javascript
复制
{item[0][sku]: 'EC1000-WMK', item[0][qty]: '1', item[1][sku]: 'POP-11', item[1][qty]: '1', form_key: 'ZuQxqBMHmidjUxEt'}
form_key: "ZuQxqBMHmidjUxEt"
item[0][qty]: "1"
item[0][sku]: "EC1000-WMK"
item[1][qty]: "1"
item[1][sku]: "POP-11"

以上数据就是这样创建的:

代码语言:javascript
复制
        $.fn.getFormData = function(){
            var data = {};
            var dataArray = $(this).serializeArray();
            console.log(data);

            console.log(dataArray);
            for(var i=0;i<dataArray.length;i++){
                console.log(dataArray);
                data[dataArray[i].name] = dataArray[i].value;
            }
            return data;
        }

但我想让它像:

代码语言:javascript
复制
[
    { "sku": "EC1000-WMK", "qty": "1" }
    { "sku": "POP-11", "qty": "1" }
]
EN

回答 1

Stack Overflow用户

发布于 2022-04-27 12:23:33

使用输入字段名类似

代码语言:javascript
复制
<input name="item.0.sku" />
<input name="item.0.qty" />
<input name="item.1.sku" />
<input name="item.2.qty" />

&然后使用这个函数,这里是将所有表单输入转换成JSON格式的函数

代码语言:javascript
复制
const jsonSerialize = ($this) => {
    $this = $this.find('input, select');
    let data = {};
    for (let i = 0; i < $this.length; i++) {
        let el = $this[i];
        let val = el.value;
        if (!val) val = "";
        let fullName = el.getAttribute("name");
        if (!fullName) continue;
        let fullNameParts = fullName.split('.');
        let prefix = '';
        let stack = data;
        for (let k = 0; k < fullNameParts.length - 1; k++) {
            prefix = fullNameParts[k];
            if (!stack[prefix]) {
                stack[prefix] = {};
            }
            stack = stack[prefix];
        }
        prefix = fullNameParts[fullNameParts.length - 1];
        if (stack[prefix]) {
            let newVal = stack[prefix] + ',' + val;
            stack[prefix] += newVal;
        } else {
            stack[prefix] = val;
        }
    }
    return data
}

let $form = $('form');
params = jsonSerialize($form)

希望这件事对你有用

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72026330

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档