Ajax笔记

Ajax——Asynchronous JavaScript and XML

一、简介

  • 异步的 JavaScript 和 XML
  • 功能:
    • AJAX 是与服务器交换数据并更新部分网页的艺术,在不重新加载整个页面的情况下
    • AJAX 是一种用于创建快速动态网页的技术
  • 为什么使用Ajax
    • Google搜索建议
    • 文档加载完更新,避免卡死
    • 局部更新网页

二、XMLHttpRequqest

1. XHR创建对象

  • 概述:
    • 所有现代浏览器均支持 XMLHttpRequest 对象(IE5 和 IE6 使用 ActiveXObject)
  • 创建对象
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");
  }

2. XHR请求

  • 向服务器发送请求,使用 XMLHttpRequest 对象的 open() 和 send() 方法
方法描述
open(method, url,async)规定请求的类型、URL 以及是否异步处理请求
method:请求的类型;GET 或 POST
url:文件在服务器上的位置
async:true(异步)或 false(同步)
send(string)将请求发送到服务器
string:仅用于 POST 请求
setRequestHeader(header,value)向请求添加 HTTP 头,仅用于POST请求
header: 规定头的名称
value: 规定头的值

2.1 GET和POST比较

  • 与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。
  • 然而,在以下情况中,请使用 POST 请求:
    • 无法使用缓存文件(更新服务器上的文件或数据库)
    • 向服务器发送大量数据(POST 没有数据量限制)
    • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

2.1.1 GET请求

//简单的GET请求,可能得到的是缓存的结果:
xmlhttp.open("GET","demo_get.asp",true);
xmlhttp.send();
//避免读取缓存,应向 URL 添加一个唯一的 ID:
xmlhttp.open("GET","demo_get.asp?t=" + Math.random(),true);
xmlhttp.send();
//如果您希望通过 GET 方法发送信息,请向 URL 添加信息:
xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);
xmlhttp.send();

2.1.2 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");
xmlhttp.send("fname=Bill&lname=Gates");

2.2 url

  • open() 方法的 url 参数是服务器上文件的地址
  • 该文件可以是任何类型的文件(.txt, .xml),或者服务器脚本文件(.asp, .php)

2.3 async

  • open() 方法的 async 参数用于指定是否使用Ajax
  • XMLHttpRequest 对象用于 AJAX,则 async 参数必须设置为 true
    • 通过 AJAX,JavaScript 无需等待服务器的响应,而是:
      • 在等待服务器响应时执行其他脚本
      • 当响应就绪后对响应进行处理
  • async=false 时,不要编写 onreadystatechange 函数
    • 把代码放到 send() 语句后面
    • 不推荐使用 async=false

3.服务器响应

属性描述
responseText获得字符串形式的响应数据
responseXML获得 XML 形式的响应数据
3.1 responseText

document.getElementById(“myDiv”).innerHTML=xmlhttp.responseText;

3.2 responseXML

//需要作为 XML 对象进行解析
xmlDoc=xmlhttp.responseXML;
txt="";
x=xmlDoc.getElementsByTagName("ARTIST");
for (i=0;i<x.length;i++)
  {
  txt=txt + x[i].childNodes[0].nodeValue + "<br />";
  }
document.getElementById("myDiv").innerHTML=txt;

4. readyState

  • 当请求被发送到服务器时,我们需要执行一些基于响应的任务, 每当 readyState 改变时,就会触发 onreadystatechange 事件, readyState 属性存有 XMLHttpRequest 的状态信息
属性描述
onreadystatechange存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数
readyState存有 XMLHttpRequest 的状态。从 0 到 4 发生变化
  • 0: 请求未初始化
  • 1: 服务器连接已建立
  • 2: 请求已接收
  • 3: 请求处理中
  • 4: 请求已完成,且响应已就绪
status200: "OK"
404: 未找到页面
``` //当 readyState 等于 4 且状态为 200 时,表示响应已就绪 //onreadystatechange 事件被触发 5 次(0 - 4),对应着 readyState 的每个变化 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/test1.txt",true); xmlhttp.send(); } ```
  • 使用 Callback 函数
    • 何时使用:网站上存在多个 AJAX 任务
<html>
<head>
<script type="text/javascript">
var xmlhttp;
function loadXMLDoc(url,cfunc)
{
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=cfunc;
xmlhttp.open("GET",url,true);
xmlhttp.send();
}
function myFunction()
{
loadXMLDoc("/ajax/test1.txt",function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
  });
}
</script>
</head>
<body>

<div id="myDiv"><h2>Let AJAX change this text</h2></div>
<button type="button" onclick="myFunction()">通过 AJAX 改变内容</button>

</body>
</html>

Ajax 高级

1. Ajax ASP/PHP

可以请求.asp或者.php界面,完成其他任务

2. Ajax数据库

同样请求.asp或者.php界面,在后端完成数据库操作

3. Ajax XML文件

x=xmlhttp.responseXML.documentElement.getElementsByTagName(“CD”);

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值