js實現表單序列化的兩種方法。

來源:互聯網
上載者:User

標籤:options   form   for   var   迴圈   pair   submit   nts   new   

 

function serialize(form) {    var parts = [],            elems = form.elements,            i = 0,            len = elems.length,            filed = null;    for (; i < len; i++) {        filed = elems[i];        switch (filed.type) {            case "select-one":            case "select-multiple":                if (filed.name.length) {                    var j = 0,                            opt,                            optLen = filed.options.length;                    for (; j < optLen; j++) {                        opt = filed.options[j];                        if (opt.selected) {                            parts.push(encodeURIComponent(filed.name) + "=" + encodeURIComponent(opt.value));                        }                    }                }                break;            case undefined:            case "submit":            case "reset":            case "file":            case "button":                break;            case "radio":            case "checkbox":                if (!filed.checked) {                    break;                }            default:                if (filed.name.length && filed.value) {                    parts.push(encodeURIComponent(filed.name) + "=" + encodeURIComponent(filed.value));                }        }    }    return parts.join("&");}

 

 這個方法重點用了HTML5中的FormData ,還有es6中for of迴圈。

  function serialize(form) {        var formData = new FormData(form),            getValue = formData.entries(),            parts = [];        for (var pair of getValue) {            parts.push(pair[0] + "=" + pair[1]);        }        return parts.join("&");    }

 

js實現表單序列化的兩種方法。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.