Jquery.Form 异步提交表单的简单实例

前端技术 2023/09/03 JavaScript

http://www.vaikan.com/docs/jquery.form.plugin/jquery.form.plugin.html#

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

复制代码 代码如下:

<form id=\"myForm\" method=\"post\" action=\"/Home/AjaxForm\">
<div>
Name:<input id=\"username\" name=\"username\" type=\"text\" />  
Password:<input id=\"password\" name=\"password\" type=\"text\" />
<br />
<input type=\"submit\" value=\"submit async\" id=\"lnkSubmit\" />
</div>
</form>

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

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

<head>    
<script type=\"text/javascript\" src=\"path/to/jquery.js\"></script>    
<script type=\"text/javascript\" src=\"path/to/form.js\"></script>     
<script type=\"text/javascript\">        
// 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!\");            
});        
});    
</script>
</head>
加上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 
       <FONT color=#ff0000> success: callBackFunc  // post-submit callback</FONT> 

        // 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(\'服务器错误!\');
        }
    }

本文地址:https://www.stayed.cn/item/6979

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。