jquery.form 异步校验_Jquery.Form 异步提交表单的简单实例

1. 在你的页面里写一个表单。一个普通的表单,不需要任何特殊的标记:

Name:  

Password:

在没有Jquery.Form组件的时候,提交表单,页面会进入阻塞模式,等待服务器端的响应。

2. 引入jQuery和Form Plugin Javascript脚本文件并且添加几句简单的代码让页面在DOM加载完成后初始化表单:

// wait for the DOM to be loaded

$(document).ready(function() {

// bind 'myForm' and provide a simple callback function

// 为myform绑定ajaxForm异步提交事件,并提供一个简单的回调函数。

$('#myForm').ajaxForm(function() {

alert("Thank you for your comment!");

});

});

加上jquery.form组件后,提交表单时,页面不会再同步提交,而是由js做异步提交,因此提交后页面不会有刷新。

3. 加入能够与服务器端进行交互的回调函数。

$(document).ready(function () {

//options是一个ajaxForm的配置对象。?

var options = {

//target: '#output1',   // target element(s) to be updated with server response

//beforeSubmit: showRequest,  // pre-submit callback

success: callBackFunc  // post-submit callback

// other available options:

//url:       url         // override for form's 'action' attribute

//type:      type        // 'get' or 'post', override for form's 'method' attribute

//dataType:  null        // 'xml', 'script', or 'json' (expected server response type)

//clearForm: true        // clear all form fields after successful submit

//resetForm: true        // reset the form after successful submit

// $.ajax options can be used here too, for example:

//timeout:   3000

};

// bind form using 'ajaxForm'

$('#myForm').ajaxForm(options);

});

// responseText是服务端的响应值。statusText是页面

// 提交状态值,success表示成功。

function callBackFunc(responseText, statusText) {

if (statusText == 'success') {

alert(responseText);

}

else{

alert(“服务端错误!”);

}

}

如果返回的是json数据则回调函数可以这么写

function resultFunction(responseText,statusText) {

if (statusText == 'success') {

if (responseText.code == 1) {

alert(responseText.message);

}

else {

alert('error occurs!');

}

}

else {

alert('服务器错误!');

}

}

服务端的代码如下:

[HttpPost]

public ActionResult AjaxForm(FormCollection form)

{

string message = "Name:" + form["username"] + " PWD: "+form["password"]  ;

//return Content(message);

return Json(new { code = 1, message = message });

}

4. 加入提交前的数据校验函数

为options对象添加 beforeSubmit属性

var options = {

//target: '#output1',   // target element(s) to be updated with server response

beforeSubmit: checkData,  // pre-submit callback

                success: callBackFunc  // post-submit callback

// other available options:

//url:       url         // override for form's 'action' attribute

//type:      type        // 'get' or 'post', override for form's 'method' attribute

//dataType:  null        // 'xml', 'script', or 'json' (expected server response type)

//clearForm: true        // clear all form fields after successful submit

//resetForm: true        // reset the form after successful submit

// $.ajax options can be used here too, for example:

//timeout:   3000

};

// pre-submit callback

function checkData(formData, jqForm, options) {

// formData is an array; here we use $.param to convert it to a string to display it

// but the form plugin does this for you automatically when it submits the data

//var queryString = $.param(formData);

// jqForm is a jQuery object encapsulating the form element.  To access the

// DOM element for the form do this:

var formElement = jqForm[0];

//alert('About to submit: \n\n' + queryString);

// here we could return false to prevent the form from being submitted;

// returning anything other than false will allow the form submit to continue

//return true;

if ($(formElement).find("#username").val() == "") {

alert("please enter username!");

return false;

} else {

return true;

}

}

验证用户名是否为空,是则提示输入,并取消表单提交。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQueryform 插件是一个简化了提交和处理的工具。它通过利用 JavaScript 的异步请求功能,实现了无刷新提交,使得页面不需要刷新就可以提交数据并接收服务器返回的结果。 使用 jQueryform 插件,我们可以通过以下几个步骤来进行提交: 1. 引入 jQuery 库和 form 插件。首先,我们需要在页面中引入 jQuery 库和 form 插件的 JavaScript 文件。可以通过在页面的代码中添加`<script>`标签来加载这些文件。 2. 编写 HTML 。在页面中添加一个 HTML ,并设置它的 id 和 action 属性,用来定义的唯一标识和提交的目标 URL。 3. 编写 JavaScript 代码。通过 jQuery 的选择器,获取元素,并使用 form 插件提供的方法进行初始化。在初始化时,我们可以设置一些选项,如设置提交的方式、成功回调函数、错误回调函数等等。 4. 处理提交。当用户触发提交按钮或其他事件时,通过 JavaScript 的事件监听函数,获取数据,并调用 form 插件的 submit 方法来提交数据。提交过程中,插件会自动将数据序列化并通过异步请求发送给服务器。 5. 处理服务器返回的结果。当服务器完成数据处理后,会返回一个结果。我们可以在提交方法的回调函数中处理这个结果,根据结果来执行不同的操作,如更新页面数据、显示成功或错误消息等。 总结起来,jQueryform 插件为提交提供了一种简洁方便的方式。它允许我们通过 JavaScript 来动态获取数据,并通过异步请求传递给服务器,实现无刷新提交和处理数据的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值