用户名: 密码: 验证码:           网站地图  高级搜索  RSS订阅  收藏本站
您的位置:主页 > 网络编程 > Ajax >

实现基本Ajax技术 4.1 完成验证

[ 来源:csdn | 作者:不详 | 更新日期:2008-3-22 15:05:48 | 人气: | 评论 0 条 ]

  我们已经介绍了Ajax技术,也知道了如何使用XMLHttpRequest对象,现在要把它们结合起来,该怎么做呢?哪些情况下需要应用Ajax技术?当然,Ajax的潜力几乎是无穷尽的,关于Ajax的使用,灵感可能源源不断。本章将展示一些例子,在这些情况下,使用Ajax技术可以让应用突飞猛进。有些情况是一目了然的,有些则不是。不过无论怎样,对Ajax应用积累的经验越多,你就越会找到自己的方法来改善应用。在这些例子中,大多数都使用Java servlet作为服务器端组件,其实每个例子也都能很容易地使用.NET、Ruby、Perl、PHP或任何其他服务器端技术来编写。

hot007.com

  4.1 完成验证

hot007.com

  关于可用性有一句金玉良言,即防患于未然,根本杜绝错误的发生。但是如果真的出现了错误,你就要第一时间通知用户。在Ajax之前,基于Web的应用必须提交整个页面才能验证数据,或者要依赖复杂的JavaScript来检查表单。尽管有些检查确实很简单,可以使用JavaScript编写,但另外一些检查则不然,完全靠JavaScript编写是办不到的。当然,在客户端编写的每一个验证例程都必须在服务器上以某种方式重写,因为用户有可能禁用JavaScript。 007网络教程网

  利用Ajax,你不用再受这个限制,不再只是编写简单的客户端验证和重复的逻辑。现在,如果你想为用户提供更能体现交互性的体验,可以简单地调用为服务器编写的验证例程。在大多数情况下,这个逻辑编写起来更简单,测试也更容易,而且完全可以借助于现有的框架。 复制于jc567.cn

  有人问,在应用中应该从哪里开始使用Ajax,我们一般会建议从验证开始。你很可能要去掉一些JavaScript,而且可以很容易地加入一些现有的服务器端逻辑。本节将介绍一个例子,这是最常见的验证之一:日期验证。 复制于jc567.cn

  这个例子的HTML很简单(见代码清单4-1)。其中有一个标准的输入框,相应的onchange()事件(当然,可以使用你认为合适的任何事件)会触发验证方法。可以看到,要调用标准的createXMLHttpRequest()方法,然后把输入值发送到ValidationServlet servlet。callback()函数从服务器得到结果,然后委托给setMessage()方法,这个方法会检查值以确定用什么颜色显示消息。

hot007.com

  代码清单4-1 validation.html

hot007.com

  <!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.getElementById("birthDate");
  var url = "ValidationServlet?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) { jc567.cn
  var mes =
  xmlHttp.responseXML
   .getElementsByTagName("message")[0].firstChild.data;
  var val =
   xmlHttp.responseXML
   .getElementsByTagName("passed")[0].firstChild.data;
  setMessage(mes, val);
  }
  }
  }
  function setMessage(message, isValid) {
  var messageArea = document.getElementById("dateMessage");
  var fontColor = "red";
  if (isValid == "true") {
  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> 文章来源于www.jc567.cn
  </body>
  </html>

共2页: 上一页 1 [2] 下一页
Tags:实现基本Ajax技术,完成验证
您的评论
用户名: 新注册) 密码: 匿名评论 [所有评论]

·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为