本案例代码已经提供下载,点击这里


AJAX即“Asynchronous JavaScript and XML”(异步JavaScript和XML),AJAX并非缩写词,而是由Jesse James Gaiiett创造的名词,是指一种创建交互式。


Ajax的核心是JavaScript对象XmlHttpRequest。该对象在Internet Explorer 5中首次引入,它是一种支持异步请求的技术。简而言之,XmlHttpRequest使您可以使用JavaScript向服务器提出请求并处理响应,而不阻塞用户。


在本文的例子中,为了让初学者对ajax的实现原理有一个更加深刻的认识,没有使用jquery等框架,整个异步请求都是通过编写javascript来完成。


本例共包括3个文件,分别为:

config.php 连接数据库

message.php 用户访问的留言界面,当用户发送留言时,将留言结果以异步请求的方式发送到message_ajax.php。

message_ajax.php  处理来自message.php中的异步请求并返回结果


下面我按实际编写的步骤来说明:

创建数据库和表

为了让问题不至于变得复杂,这里我是在test数据库中创建了一个表t_message。SQL语句如下:


create table t_message(
id int auto_increment primary key,
email varchar(100),
content text
);


编写用户留言界面


留言界面非常简洁,就是一个表单,在message.php中添加以下html代码如下:

<div style="width:800px;margin:0 auto;">
	<form action="#" >
	 <fieldset>
    <legend>Leave Message Here</legend>
    <table>
		<tr>
			<td>Email:</td>
			<td><input name="email"  id="email" type="email" /></td>
		</tr>
		<tr>
			<td>Content:</td>
			<td><textarea name="content" id="content" cols="80" rows="6" ></textarea></td>
		</tr>
		<tr>
			<td></td>
			<td><input name="button1" type="button" value="Post" onclick="doRequestUsingPOST()" /></td>
		</tr>
	</table>
  </fieldset>
 </form>
</div>


异步请求


  • 创建一个XMLHttpRequest的引用
  • 告诉XMLHttpRequest对象,哪个函数会处理XMLHttpRequest对象状态的改变,为此要设置onreadystatechange属性
  • 指定请求的属性。open()
  • 将请求发送给服务器。send()
  • xmlHttp.responseText将响应提供为一个串



创建一个XMLHttpRequest的引用


var xmlHttp;
  function createXMLHttpRequest(){
    if(window.ActiveXObject)
      {
         xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
      }
      else if(window.XMLHttpRequest)
      {
        xmlHttp = new XMLHttpRequest();
      }else{
        alert("浏览器不支持XMLHttpRequest对象");
      }
  }



创建查询字符串

function createQueryString(){
    var email = document.getElementById("email").value;
    var content = document.getElementById("content").value;
    var queryString = "email="+ email + "&content="+ content ;
    //alert(queryString);
    return queryString;
  }


以POST方式发送异步请求

function doRequestUsingPOST(){
    createXMLHttpRequest();

    var url = "message_ajax.php?timeStamp=" + new Date().getTime();
    var queryString = createQueryString();
    xmlHttp.open("POST",url,true);
    xmlHttp.onreadystatechange = handleStateChange;
    xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded;");
    xmlHttp.send(queryString);
  }


处理状态变更,解析message_ajax.php返回的结果

function handleStateChange(){
     if(xmlHttp.readyState == 4){
        if(xmlHttp.status == 200){
           parseResult();
           //alert("OK");
        }
     }
  }

  function parseResult(){

    var responseDiv = document.getElementById("newmessage");
    if(responseDiv.hasChildNodes()){
      responseDiv.removeChild(responseDiv.childNodes[0]);
    }
    var responseText = xmlHttp.responseText;//document.createTextNode(xmlHttp.responseText);
    responseDiv.innerHTML = responseText;
    //responseDiv.appendChild(responseText);
  }


服务端处理异步请求


然后我们看下服务端message_ajax.php是怎样处理请求的


<?php
        include_once("config.php");
    	$email = strip_tags($_POST['email']);
    	$content = strip_tags($_POST['content']);
    	$sql1 = "insert into t_message values(NULL, '"  . $email . "' ,'".$content."')";

        mysql_query($sql1);

      $sql = "SELECT * FROM `t_message` order by id desc LIMIT 10";
      $result = mysql_query($sql);
      $responseText = "<table>";
      while($message = mysql_fetch_array($result)){
      	$onemessage = "
				<tr>
					<th style='background-color:gray;'>Email:</th>
					<td>".$message['email']."</td>
				</tr>
				<tr style='border-bottom:1px gray dashed;'>
					<th style='background-color:gray;'>Content:</th>
					<td>".$message['content']."</td>
				</tr>";
				$responseText = $responseText.$onemessage;
			}
			$responseText = $responseText."</table>";
			echo $responseText;

?>


从上面代码可以看到,服务端首先需要接收客户端发送过来的请求,在本例中发送的参数就是email和content。

然后,服务端将这些数据保存到数据库中,并查询出数据库中最近的10条留言信息,构造成HTML字符串,并echo。

于是客户端便可接收到,实现无刷新显示最近的10条留言(当然需要留言超过10条的时候)。