AJAX——初遇
来源:互联网 发布:360软件助手 编辑:程序博客网 时间:2024/06/08 02:44
AJAX学习笔记
什么是AJAX?
AJAX = 异步 JavaScript 和 XML。
AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
很多使用 AJAX 的应用程序案例:新浪微博、Google 地图、开心网等等。
AJAX的基础-XMLHttRequest对象
所有现代浏览器均支持XMLHttpRequest对象(IE5和IE6使用ActiveXObject)。
为了兼顾两者,需要判断是否支持XMLHttpRequest。
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"); }
XMLHttpRequest对象用于和服务器交换数据
向服务端发送请求,使用对象所提供的方法
GET请求
为了避免得到缓存结果,向URL添加唯一的ID
xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);xmlhttp.send();
POST请求
如果需要想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");
open()方法的url参数是服务器上文件的地址:”ajax_test.asp”,该文件可以是任何类型的文件,比如.txt 和 .xml,或者服务器脚本文件,比如.asp和.php
关于同步Async = false异步Async = true的问题
如需使用 async=false,请将 open() 方法中的第三个参数改为 false:
并不推荐使用 async=false,但是对于一些小型的请求,也是可以的。
请记住,JavaScript 会等到服务器响应就绪才继续执行。如果服务器繁忙或缓慢,应用程序会挂起或停止。
xmlhttp.open("GET","test1.txt",false);xmlhttp.send();document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
如需使用 async=true ,请规定在响应处于 onreadystatechange 事件中的就绪状态时执行的函数:
xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById("myDiv").innerHTML=xmlhttp.responseText; } }xmlhttp.open("GET","test1.txt",true);xmlhttp.send();
对于 web 开发人员来说,发送异步请求是一个巨大的进步。很多在服务器执行的任务都相当费时。AJAX 出现之前,这可能会引起应用程序挂起或停止。
AJAX-服务器响应
需要获取来自服务器的响应,使用 XMLHttpRequest 对象的 responseText 或 responseXML 属性
responseText属性
responseText属性返回字符串形式的响应:
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
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;
AJAX - onreadystatechange 事件
当请求被发送到服务器时,我们需要执行一些基于响应的任务。
每当 readyState 改变时,就会触发 onreadystatechange 事件。
readyState 属性存有 XMLHttpRequest 的状态信息。
当 readyState 等于 4 且状态为 200 时,表示响应已就绪:
xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById("myDiv").innerHTML=xmlhttp.responseText; } }
注释:onreadystatechange 事件被触发 5 次(0 - 4),对应着 readyState 的每个变化。
使用Callback函数
allback 函数是一种以参数形式传递给另一个函数的函数。
如果您的网站上有多个 AJAX 任务,那么您应该为其创建 XMLHttpRequest 对象编写一个标准的函数,并为每个 AJAX 任务调用该函数。
该函数调用应该包含 URL 以及发生 onreadystatechange 事件时执行的任务(每次调用可能不尽相同):
function myFunction(){loadXMLDoc("ajax_info.txt",function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { document.getElementById("myDiv").innerHTML=xmlhttp.responseText; } });}
- AJAX——初遇
- Ajax:前台利器—Ajax
- Ajax(二) — Ajax初步 : $.post 方法与 $.ajax 方法
- 掌握 Ajax ——Ajax 简介
- Ajax入门——什么是Ajax
- Ajax——ajax调用数据总结
- Ajax——ajax调用数据总结
- Ajax —— 一言不合就谈Ajax
- jQuery AJAX —篇三 $.ajax()
- AJAX 快速入门—什么是ajax?
- jquery——ajax
- AJAX——入门
- ajax——XMLHttpRequest
- JQuery——AJAX
- JavaScript——AJAX
- AJAX——概述
- AJAX——UpdatePanel
- 【AJAX】——初识
- JSP(1)入门
- 用 Keras 编写你的第一个人工神经网络(Python)—— Jinkey 翻译
- 关于SSM @ResponseBody 返回数据中文乱码解决问题
- HDU6205-card card card
- 动态规划
- AJAX——初遇
- merge-two-sorted-lists
- Shot边界检测----2001-2007TRECVID比赛算法总结
- 前端奇淫技巧(二)之上下左右居中
- parseInt(1 / 0, 19)
- bat脚本设置系统环境变量即时生效
- 发送邮件增加同步锁
- Tomcat的HTTP与AJP协议
- Simple Java Mail的使用