之前写过一篇Post用Ajax查询用户名是否重名,这次我们用JQuery的插件validate来实现,更加简单,相比之前用xmlhttprequest来说,不用考虑浏览器兼容的问题,这也是使用是Jquery这个轻量级框架的特点之一。
      此处用的是ASP.NET MVC RC,aspx代码如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="TestValidation1.aspx.cs" Inherits="DemoMVCForm.Views.FormDemo.TestValidation1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    
<title>Demo</title>
    
<script src="http://www.cnblogs.com/Scripts/jquery-1.2.6.min.js" type="text/javascript"></script>
    
<script src="http://www.cnblogs.com/Scripts/jquery.validate.js" type="text/javascript"></script>
    
<script type="text/javascript">
        $(document).ready(
function() {
            $(
"#form-sign-up").validate({
                rules: {
                    login: {
                    required: 
true,
                      
//here invoke related action
                        remote: '<%=Url.Action("IsLoginAvailable", "FormDemo") %>'
                    }
                },
                messages: {
                    login: {
                        required: 
"请输入用户名",
                        remote: jQuery.format(
"{0} 已经有人用了")
                    }
                },
                
// set this class to error-labels to indicate valid fields 
                success: function(label) {
                    
// set   as text for IE 
                    label.html(" ").addClass("checked");
                }
            });
        });
</script>
</head>
<body>
    
<form action="<%=Url.Action("Register", "FormDemo")%>" method="post" id="form-sign-up">
    
<h1>Demo表单</h1>
    
<table id="inputArea">
        
<tr>
            
<td>用户名 (试试输入 Petter):</td>
            
<td><input type="text" name="login" id="login" /></td>
        
</tr>
        
<tr>
            
<td colspan="2" align="center"><br /><input type="submit" /></td>
        
</tr>
    
</table>
</form>
</body>
</html>

Asp.net MVC支持Json,所有返回Json的结果,直接使用是JsonResult,看代码cs,很简单:

cs
  /// <summary>
    
/// FormDemoController
    
/// </summary>
    
/// <remark>Author : PetterLiu 2009-1-12 17:20  DEV-LIUJUNYUAN</remark>
    public class FormDemoController : Controller
    {
        
public JsonResult IsLoginAvailable(string login)
        {
            
//TODO: Do the validation
            JsonResult result = new JsonResult();
            
if (login == "Petter")
                result.Data 
= false;
            
else
                result.Data 
= true;

            
return result;
        }
    }


相关引用:
   Asp.net MVC       http://www.asp.net/mvc
   JQuery                http://www.jquery.com
   jquery-validation  http://bassistance.de/jquery-plugins/jquery-plugin-validation/


   Author:PetterLiu  http://www.cnblogs.com/wintersun/  

 

posted on 2009-02-08 17:08  PetterLiu  阅读(2977)  评论(0编辑  收藏  举报