jquery序列化表單插件

    (function($) {
        $.fn.serializeJson = function() {
            var inputs = $(this).find("input,textarea,select");
            var o = {};
            $.each(inputs, function(i, n) {
                switch (n.nodeName.toUpperCase()) {
                    case "INPUT":
                        if ($(n).is(":checkbox")) {
                            if ($(n).is(":checked")) {
                                o[n.name] = true;
                            } else {
                                o[n.name] = false;
                            }
                        } else if ($(n).is(":radio")) {
                            if ($(n).is(":checked")) {
                                o[n.name] = n.value;
                            }
                        } else if ($(n).is(":file")) {
                            return true;
                        } else {
                            if (n.name) {
                                o[n.name] = n.value;
                            }
                        }

                        break;
                    case "TEXTAREA":
                        o[n.name] = $(n).val();
                        break;
                    case "SELECT":
                        o[n.name] = n.value;
                        break;
                }
            });
            return o;
        }

    })(jQuery);
input、select、rextarea需要設置name,序列化后的json的key即為name
用法:$(ele).serializeJson ()
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容