Ajax基礎教程學習(2.1)_完成驗證

來源:互聯網
上載者:User

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" >

<html> <head>    <title>Using Ajax for validation</title>    <script type="text/javascript">      
 var xmlHttp;       
 function createXMLHttpRequest() {           
    if (window.ActiveXObject) {               
        xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");           
    }else if (window.XMLHttpRequest) {              
        xmlHttp = new XMLHttpRequest();           
    }       
 }      
 
 function validate() {           
    createXMLHttpRequest();         
    var date = document.getElementByIdx_x("birthDate");          
    var url = "Handler.ashx?birthDate=" + escape(date.value);           
    xmlHttp.open("GET", url, true);           
    xmlHttp.onreadystatechange = callback;           
    xmlHttp.send(null);       
 }       
   
    function callback() {           
        if (xmlHttp.readyState == 4) {          
         if (xmlHttp.status == 200) {                  
             var mes =xmlHttp.responseXML.getElementsByTagName_r("message")[0].firstChild.data;          
             var val =xmlHttp.responseXML.getElementsByTagName_r("passed")[0].firstChild.data;
             setMessage(mes, val);               
          }          
        }       
     }  
                  
function setMessage(message, isValid) {          
    var messageArea = document.getElementByIdx_x("dateMessage");           
    var fontColor = "red";         
    if (isValid) {            
        fontColor = "green"; 
                     
        }           
    messageArea.innerHTML = "<font color=" + fontColor + ">" + message + " </font>";      
     }   
    
</script> </head> <body>    <h1>Ajax Validation Example</h1>    Birth date: <input type="text" size="10" id="birthDate" onchange="validate();"/>    <div id="dateMessage"></div> </body>

</html>

服務端代碼

 

<%@ WebHandler Language="C#" class="Handler" %>

using System;
using System.Web;
using System.Text;
using System.Collections;

public class Handler : IHttpHandler {
    public void ProcessRequest (HttpContext context) {
        bool pass = Validate(context.Request.QueryString["birthDate"]);
        context.Response.ContentType = "text/xml";
        context.Response.AddHeader("Cache-Control","no-cache");
        String message = "您輸入的日期不正確.";
        if (pass)
        {
            message = "您輸入的日期正確.";
        }
        context.Response.Write("<response>");
        context.Response.Write("<passed>"+pass+"</passed>");
        context.Response.Write("<message>" + message + "</message>");
        context.Response.Write("</response>");
        context.Response.End();
           
      
    }

    public bool Validate(string date)
    {
        bool isValid = true;
        if (date != null)
        {
            try
            {
                DateTime.Parse(date);
            }
            catch (Exception)
            {
                isValid = false;
            }
        }
        else
        {
            isValid = false;
        }

        return isValid;
       
    }
       
       
 
    public bool IsReusable {
        get {
            return false;
        }
    }

}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.