jQuery ajax提交Form表單實(shí)例(附demo源碼)
來源:易賢網(wǎng) 閱讀:2015 次 日期:2016-07-08 14:59:59
溫馨提示:易賢網(wǎng)小編為您整理了“jQuery ajax提交Form表單實(shí)例(附demo源碼)”,方便廣大網(wǎng)友查閱!

本文實(shí)例講述了jQuery ajax提交Form表單的方法。分享給大家供大家參考,具體如下:

Jquery的$.ajax方法可以實(shí)現(xiàn)ajax調(diào)用,要設(shè)置url,post,參數(shù)等。

如果要提交現(xiàn)有Form需要寫很多代碼,何不直接將Form的提交直接轉(zhuǎn)移到ajax中呢。

以前的處理方法

如Form代碼如下:

<form id="Form1" action="action.aspx" method="post" >

名稱:<input name="name" type="text" /><br />

密碼:<input name="password" type="password" /><br />

手機(jī):<input name="mobile" type="text" /><br />

說明:<input name="memo" type="text" /><br />

<input type="submit" value="提 交" />

</form>

當(dāng)提交后,會(huì)跳轉(zhuǎn)到action.aspx頁面。并可以通過Request.Params["name"]可以取到值。

思考

如果不想刷新頁面使用ajax,就又要在$.ajax中指定url,等信息,不好維護(hù)。

在網(wǎng)上查了一下,老早以前老外就有解決方案了。使用ajax直接按照Form信息直接提交。不刷新頁面。

參考資料:http://jquery.malsup.com/form/

很好用,但我還是愿意自己寫個(gè)自己用的。

核心JS代碼

//將form轉(zhuǎn)為AJAX提交

function ajaxSubmit(frm, fn) {

  var dataPara = getFormJson(frm);

  $.ajax({

    url: frm.action,

    type: frm.method,

    data: dataPara,

    success: fn

  });

}

//將form中的值轉(zhuǎn)換為鍵值對(duì)。

function getFormJson(frm) {

  var o = {};

  var a = $(frm).serializeArray();

  $.each(a, function () {

    if (o[this.name] !== undefined) {

      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;

}

ajaxSubmit方法第一個(gè)參數(shù),是要提交的form,第二個(gè)參數(shù)是ajax調(diào)用成功后的處理函數(shù)。

將form的action傳遞給ajax的url,form的method傳遞給ajax的type,再將格式化后的表單內(nèi)容傳遞給data。

getFormJson方法將form的元素轉(zhuǎn)化為json格式鍵值對(duì)。形如:{name:'aaa',password:'tttt'},注意將同名的放在一個(gè)數(shù)組里。

調(diào)用

//調(diào)用

$(document).ready(function(){

  $('#Form1').bind('submit', function(){

    ajaxSubmit(this, function(data){

      alert(data);

    });

    return false;

  });

});

在ajaxSubmit方法調(diào)用前,可驗(yàn)證數(shù)據(jù)是否正確,在alert(data)處可加入自己調(diào)用返回后處理代碼。

在調(diào)用ajaxSubmit方法后,必須添加return false;語句防止Form真實(shí)提交。

希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:jQuery ajax提交Form表單實(shí)例(附demo源碼)
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)