AJAX之学习笔记(持续更新......)

  以前的学习都是在Evernote上做的笔记,之前也在博客园注册过,但是一直没用,就荒废了。最近想既然是学技术的,用这个来记我的一些日常学习笔记是在好不过了。

  总之加油吧~~~希望自己能早日摆脱新手这个称呼嘻嘻(*^__^*) 

  1、AJAX的定义

AJAX=Asynchronous JavaScript and XML(异步的JavaScript和XML)——此处应先了解HTML、XHTML、CSS、JavaScript和DOM结构。

AJAX是一种新方法,不是新的编程语言,可以在不需要重新加载网页的情况下,与服务器交换数据以更新网页。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。

  2、AJAX的工作原理

(1)、创建XMLHttpRequest对象

XMLHttpRequest用于在后台和服务器交换数据。所有浏览器都支持(IE5、IE6使用ActiveXObject)

  创建XMLHttpRequest对象:(所有现代浏览器(IE7+、Firefox、Chrome、Safari 以及 Opera)均内建 XMLHttpRequest 对象)

  语法:variable=new XMLHttpRequest();

  老版本的IE5、IE6使用ActiveX对象:variable=new ActiveXObject("Mcrosoft.XMLHttp");

为了应对所有的现代浏览器,包括 IE5 和 IE6,请检查浏览器是否支持 XMLHttpRequest 对象。如果支持,则创建 XMLHttpRequest 对象。如果不支持,则创建 ActiveXObject :

var xmlhttp;

if(window.XMLHttpRequest)

{

// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();

}else{

// code for IE6, IE5
xmlhttp=new ActiveXObject("Mcrosoft.XMLHttp");

}

  (2)、向服务器发送请求

使用open()和send()方法:xmlhttp.open("GET","test.txt",true);xmlhttp.send();

下面来介绍open()和send()方法:

open(method,url,async):规定请求的类型、URL 以及是否异步处理请求。method(请求类型;GET或POST),url(文件在服务器的位置),async(true——异步或false——同步);open() 方法的 url 参数是服务器上文件的地址。该文件可以是任何类型的文件,比如 .txt 和 .xml,或者服务器脚本文件,比如 .asp 和 .php (在传回响应之前,能够在服务器上执行任务)。

send(string):将请求发送到服务器,string(仅用于post请求)

这里我简单的介绍一下GET和POST:

一个简单的GET请求:xmlhttp.open("GET","demo_get.asp",true);xmlhttp.send();//可能得到的是缓存的结果

此时可以向url添加一个唯一的ID:xmlhttp.open("GET","demo_get.asp?t="+Math.random,true);xmlhttp.send();

eg:

<html>
<head>
<script type="text/javascript">
function loadXMLDoc()
{
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","/ajax/demo_get.asp?t=" + Math.random(),true);
xmlhttp.send();
}
</script>
</head>
<body>

<h2>AJAX</h2>
<button type="button" onclick="loadXMLDoc()">请求数据</button>
<div id="myDiv"></div>

</body>
</html>

如果希望通过GET发送消息,可以这样:

xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);
xmlhttp.send();

POST请求:

一个简单的POST请求:

xmlhttp.open("POST","demo_post.asp",true);
xmlhttp.send();

如果需要像 HTML 表单那样 POST 数据,请使用 setRequestHeader() 来添加 HTTP 头。然后在 send() 方法中规定你希望发送的数据:

xmlhttp.open("POST","ajax_test.asp",true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");//CONTENT-TYPE:application/x-www-form-urlencoded含义是表示客户端提交给服务器文本内容的编码方式 是URL编码,即除了标准字符外,每字节以双字节16进制前加个“%”表示.setRequestHeader(header,value),向请求添加 HTTP 头。header: 规定头的名称,value: 规定头的值。
xmlhttp.send("fname=Bill&lname=Gates");


在以下情况中,请使用 POST 请求:

  • 无法使用缓存文件(更新服务器上的文件或数据库)
  • 向服务器发送大量数据(POST 没有数据量限制)
  • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

其余情况一般使用GET方法。

  (3)、服务器响应

使用XMLHttpRequest 对象的 responseText 或 responseXML 属性。

responseText:获得字符串形式的响应数据。

responseText 属性返回字符串形式的响应,因此可以这样使用:

document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

responseXML:获得XML形式的响应数据。

  (4)、onreadystatechange事件

每当 readyState 改变时,就会触发 onreadystatechange 事件。

readyState 属性存有 XMLHttpRequest 的状态信息。

下面是XMLHttpRequest对象的三个重要属性:

onreadystatechange:存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。onreadystatechange 事件被触发 5 次(0 - 4),对应着 readyState 的每个变化。

readystate:存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

0: 请求未初始化

1: 服务器连接已建立

2: 请求已接收

3: 请求处理中

4: 请求已完成,且响应已就绪

status:200:"OK",404:未找到页面

 

使用callback函数:以参数形式传递给另一个函数的函数。该函数调用应该包含 URL 以及发生 onreadystatechange 事件时执行的任务(每次调用可能不尽相同)。

eg:

function myFunction()
{
loadXMLDoc("ajax_info.txt",function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
  });
}
showHint()函数:
eg:
function showHint(str)
{
var xmlhttp;
if (str.length==0)
  {
  document.getElementById("txtHint").innerHTML="";
  return;
  }
if (window.XMLHttpRequest)
  {// code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {// code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("txtHint").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","gethint.asp?q="+str,true);
xmlhttp.send();
}

源代码解释:

如果输入框为空 (str.length==0),则该函数清空 txtHint 占位符的内容,并退出函数。

如果输入框不为空,showHint() 函数执行以下任务:

a.创建 XMLHttpRequest 对象

b.当服务器响应就绪时执行函数

c.把请求发送到服务器上的文件

d.请注意我们向 URL 添加了一个参数 q (带有输入框的内容)

 

posted @ 2015-08-19 18:56  大发朵朵  阅读(246)  评论(0编辑  收藏  举报