Ajax传值方式两种:POST,GET
客户端传给服务器端的交互的值的形式有三种:字符串、XML、JSON
处理服务器响应:XMLHttpRequest对象提供了两个可以用来访问服务器响应的属性,一个是responseText将响应呈现为一个字符串,另一个responseXML将响应呈现为一个XML对象,其实对返回值的通常写法:通过responseText获取返回的字符串,在通过XDOM的解析器加载后,获取Document对象,在进行其他操作。
var back_val = xmlHttp.responseText;
var xmlDoc = loadXMLString(back_val):
合为一句为:var xmlDoc = xmlHttp.responseXML;  这样可以直接获取Document对象,进行其他操作。

GET方式:

function getXHR(){
   if (window.XmlHttpRequest) {
       return new window.XMLHttpRequest();
   } else if (window.ActiveXObject) {
       return new window.ActiveXObject('Microsoft.XMLHTTP');   } else {
     alert('您的不能创建XmlHttpRequest')
   }
 }
 var xhr = getXHR();
 xhr.onreadystatechange = function(){
    if (xhr.readyState == 4) {
     if(xhr.status == 200) {
      alert(xhr.responseText);
      } else {
      //alert('请求失败!');
      return false;
     }
 }
 xhr.open('get', url + '?time=' + time + ‘&username=’ + username, true);
 xhr.send(null);


GET方式传值其实就和平时使用超链接传值方式差不多,用?/&方式通过key=value方式传到服务器,服务器通过getParameter的方式来获取值。如果传值中用中文的话,需要进行转码:

xhr.open('get', url + '?time=' + time + '&username=' + encodeURL(username), true);


服务器中接收是可以转回来

String username = request.getParameter('username');
 username = new String(username.getBytes(('ISO-8859-1')), 'uft-8');


GET方式总结:用get方式可传送简单数据,但大小一般都限制在1KB下,数据追加到url中发送(http的header传送)。也就是说,浏览器将各个表单字段元素及其数据按照URL参数的格式附加在请求行中的资源路径后面。另外最重要的一点是,它会被客户端的浏览器缓存起来,那么,别人可以从浏览器的历史记录中读取到客户的数据,比较帐号密码,因此get方法在某些情况下,是会带来严重的安全性问题。

POST方式:前面和get一样的省略

var queryVal = 'time=' + time + '&username = ' + username:
 xhr.open('post', url, true);
 xhr.setRequstHeader('Content-Type', 'application/x-www-form-urlencoded');
 xhr.send(queryVal);


和GET的不同的是,url上面不用加需要传过去的值,而且需要加上一句xhr.setRequstHeader('Content-Type', 'application/x-www-form-urlencoded'); send方法需要传拼接好的参数作为值,而不是send(null)。
POST总结:使用post方式时,浏览器把各表单字段及其数据作为HTTP消息实体内容发送Web服务器,而不是作为URL地址参数形式传递,所以使用post方式传递的数据量比使用get方式传递的数据量大的多。