Jquery基于Ajax方法自定義無(wú)刷新提交表單Form實(shí)例
來(lái)源:易賢網(wǎng) 閱讀:2704 次 日期:2014-11-17 14:35:34
溫馨提示:易賢網(wǎng)小編為您整理了“Jquery基于Ajax方法自定義無(wú)刷新提交表單Form實(shí)例”,方便廣大網(wǎng)友查閱!

本文實(shí)例講述了Jquery基于Ajax方法自定義無(wú)刷新提交表單Form的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:

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

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

以前的處理方法:

如Form代碼如下:

復(fù)制代碼 代碼如下:<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 />

說(shuō)明:<input name="memo" type="text" /><br />

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

</form>

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

思考:

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

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

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

核心JS代碼:

復(fù)制代碼 代碼如下://將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)用:

復(fù)制代碼 代碼如下:$(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)用返回后處理代碼。

更多信息請(qǐng)查看IT技術(shù)專欄

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

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

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(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)