如何创建动态html表单的创建JSON对象(表单元素)?

时间:2014-12-19 10:17:16

标签: javascript jquery json forms dom

尝试创建动态HTML表单并保存它们,我可以使用bootstrap创建动态表单但是在提交时我很难创建这个动态表单的JSON。 我希望保存这样的东西

{
 "form" :
    [

        {
            "name" : "username",
            "id" : "txt-username",
            "caption" : "Username",
            "type" : "text",
            "placeholder" : "E.g. user@example.com"
        },
        {
            "name" : "password",
            "caption" : "Password",
            "type" : "password"
        },
        {
            "type" : "submit",
            "value" : "Login"
        }
    ]
}

我不确定如何实现这一点。

1 个答案:

答案 0 :(得分:4)

这应该这样做:

function getAttrs(DOMelement) {
    var obj = {};
    $.each(DOMelement.attributes, function () {
        if (this.specified) {
            obj[this.name] = this.value;
        }
    });
    return obj;
}

$("form").each(function () {
    var json = {
        "form": []
    };
    $(this).find("input").each(function () {
        json.form.push(getAttrs(this));
    });

    $(this).find("select").each(function () {
        var select = getAttrs(this);
        select["type"] = "select";
        var options = [];
        $(this).children().each(function () {
            options.push(getAttrs(this));
        });
        select["options"] = options;
        json.form.push(select);
    });

    console.log(json);
});

DEMO:http://jsfiddle.net/j1g5jog0/

更新:http://jsfiddle.net/j1g5jog0/5/