Jquery序列化form表單對象

在web開發(fā)過程中帅刀,難免需要提交表單,js提交表單數(shù)據(jù)需要將所有input控件的值全部獲得,然后組合成一個JSONObject對象傳入后臺盲镶,難免有些麻煩和瑣碎,有好幾種方法可以獲得全部的表單數(shù)據(jù)蝌诡,今天介紹其中一種序列化serialize()方式溉贿;

  • serialize()
$("#myForm").seroalize()
# myFrom 為form標簽的id;

把id為myForm的form標簽內(nèi)所有的控件全部序列化成json字符串浦旱;如:

key1=value1&key2=value2
key:是控件的name屬性值
  • serializeArr()
$("#myForm").seroalizeArr()
# myFrom 為form標簽的id宇色;

把id為myForm的form標簽內(nèi)所有的控件全部序列化成json字符串并添加到一個數(shù)組;如:

[
    {key1:value1},
    {key2:value2}
]
key:是控件的name屬性值
  • serializeObject()
$("#myForm").seroalizeArr()
# myFrom 為form標簽的id颁湖;

把id為myForm的form標簽內(nèi)所有的控件全部序列化成JSONObject宣蠕;如:

{
    key1:value1,
    key2:value2
}
key:是控件的name屬性值

但是jquery沒有內(nèi)置serializeObject()方法,需要對重寫該方法

$.fn.serializeObject = function () {
    var o = {};
    var a = this.serializeArray();
    $.each(a, function () {
        if (o[this.name]) {
            if (!o[this.name].push) {
                o[this.name] = [o[this.name]];
            }
            o[this.name].push(this.value || '');
        } else {
            o[this.name] = this.value || '';
        }
    });
    return o;
};

但是在ajax請求時甥捺,使用該方法獲得的對象直接傳入后臺會有400錯誤抢蚀,這時候需要添加headers、和contentType镰禾;同時需要對獲得對象轉(zhuǎn)化成字符串類型思币;

var formData = $("#myForm").serializeObject();
console.log(formData);
$.ajax({
    url: product.url.insert(),
    type: "POST",
    headers: {
        Accept: "text/html, application/xhtml+xml, */*"
    },
    contentType: 'application/json;charset=utf-8',
    data: JSON.stringify(formData),
    async: false,
    dataType: 'JSON',
    success: function (res) {
    }
    error:function(){
    }

如果 控件name 值和javaBean字段值相同鹿响,那么后臺可以直接接受該對象參數(shù),不需要每個字段寫一個參數(shù)谷饿,使用@RequesBody注解修飾惶我;

public String test(@RequesBody User user)
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市博投,隨后出現(xiàn)的幾起案子绸贡,更是在濱河造成了極大的恐慌,老刑警劉巖毅哗,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件听怕,死亡現(xiàn)場離奇詭異,居然都是意外死亡虑绵,警方通過查閱死者的電腦和手機尿瞭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來翅睛,“玉大人声搁,你說我怎么就攤上這事〔斗ⅲ” “怎么了疏旨?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長扎酷。 經(jīng)常有香客問我檐涝,道長,這世上最難降的妖魔是什么法挨? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任谁榜,我火速辦了婚禮,結果婚禮上凡纳,老公的妹妹穿的比我還像新娘窃植。我一直安慰自己,他們只是感情好惫企,可當我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布撕瞧。 她就那樣靜靜地躺著,像睡著了一般狞尔。 火紅的嫁衣襯著肌膚如雪丛版。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天偏序,我揣著相機與錄音页畦,去河邊找鬼。 笑死研儒,一個胖子當著我的面吹牛豫缨,可吹牛的內(nèi)容都是我干的独令。 我是一名探鬼主播,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼好芭,長吁一口氣:“原來是場噩夢啊……” “哼燃箭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起舍败,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤酪惭,失蹤者是張志新(化名)和其女友劉穎壳快,沒想到半個月后协饲,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體御滩,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年厕诡,在試婚紗的時候發(fā)現(xiàn)自己被綠了累榜。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡灵嫌,死狀恐怖壹罚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情醒第,我是刑警寧澤渔嚷,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布进鸠,位于F島的核電站稠曼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏客年。R本人自食惡果不足惜霞幅,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望量瓜。 院中可真熱鬧司恳,春花似錦、人聲如沸绍傲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽烫饼。三九已至猎塞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間杠纵,已是汗流浹背荠耽。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留比藻,地道東北人铝量。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓倘屹,卻偏偏與公主長得像,于是被迫代替她去往敵國和親慢叨。 傳聞我的和親對象是個殘疾皇子纽匙,可洞房花燭夜當晚...
    茶點故事閱讀 44,969評論 2 355

推薦閱讀更多精彩內(nèi)容

  • ??JavaScript 最初的一個應用哄辣,就是分擔服務器處理表單的責任,打破處處依賴服務器的局面赠尾。 ??盡管目前的...
    霜天曉閱讀 668評論 0 3
  • 本人做php的,最近發(fā)現(xiàn)JS真的是博大精深啊,比PHP難.在HTML中力穗,表單是由form元素來表示的,但是在jav...
    linfree閱讀 2,165評論 3 17
  • 01 為什么早產(chǎn)兒有時候需要恒溫器或者呼吸機气嫁?為什么剛出生的嬰兒晝夜不分当窗,幾個月后就可以晚上睡整覺?為什么嬰兒出生...
    風叔UncleWind閱讀 1,357評論 0 1
  • 有時思考總是太過簡單寸宵,別人說的輕易就相信了崖面,沒去驗證,導致出現(xiàn)錯誤梯影,悔不當初巫员。 避免出現(xiàn)這種低級的錯誤,每個人都需...
    翠霞_0256閱讀 143評論 0 2
  • 上大學的時候甲棍,大家都傲氣的不得了简识。大學是一所排名還不錯的學校,進來的都在高中班里甚至在全年級都是靠前的人感猛。大家土里...
    余子亞閱讀 598評論 2 3