[01] AJAX
1、概述
2、XMLHttpRequest对象
- xmlHttp = new XMLHttpRequest();
- //老版本IE(IE5/IE6)xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
if(window.ActiveObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
if(window.ActiveObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
2.1 属性
| 属性名 | 说明 | 备注 |
| readyState | 返回当前状态 | 0-4共五个值 0:“未初始化”,表已经创建XMLHttpRequest对象,但尚未初始化请求对象 1:“打开”,已调用XMLHttpRequest的open()方法,准备好发送请求 2:“发送”,已调用XMLHttpRequest的send()方法,已发送请求,尚未收到响应 3:"正在接收",已收到响应头信息,消息体还没有完全接收 4:“已加载”,响应已完全接收 |
| status | 返回当前服务器状态 | 状态码详见《HTTP状态消息》 |
| statusText | 同status,但以文字表示 | 同上 |
| onreadystatechange | 事件触发器 | readyState、status发生变化时会触发该项,往往指定为JS函数,如: xmlHttpRequest.onreadystatechange = callback; |
| responseText | 接收服务器端返回的文本 | 返回内容以字符串形式存在 |
| responseXML | 接收服务器响应 | 响应内容若以XML存在,可解析为DOM对象,如: var message = xmlHttp.responseXML.getElementsByTagName("message")[0].firstChild.data; |
2.2 方法
- open(DOMString method, DOMString uri, boolean async, DOMString username, DOMString password)
- send()
- setRequestHeader(DOMString header, DOMString value)
- getResponseHeader(DOMString header)
- getAllResponseHeaders()
- abort()
2.2.1 open
- method 指定请求方式,如GET/POST
- uri 指定XMLHttpRequest对象请求的具体URI,绝对或相对URI均可
- async 指定该请求是否异步,默认true
- username/password 对于需要认证的服务器,可以提供该两项参数
var url = "validate?custname=" + escape(custname.value);
xmlHttp.open("GET", url, true);
var url = "validate?custname=" + escape(custname.value);
xmlHttp.open("GET", url, true);
2.2.2 send
xmlHttp.open("POST", "login", true);
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlHttp.send("username="+encodeURI(username));
xmlHttp.open("POST", "login", true);
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlHttp.send("username="+encodeURI(username));
2.2.3 其他方法
- setRequestHeader(DOMString header, DOMString value)
- 用来设置请求头信息,参数分别为请求头名字和对应的值
- 该方法必须在open之后调用,否则会发生异常
- getResponseHeader(DOMString header)
- 根据一个响应头的名字返回其对应的值
- 如果响应头信息没有返回客户端,则返回null
- getAllResponseHeaders()
- 返回所有的响应头信息,使用键值对的形式表示名字和值
- abort()
- 用来暂停一个与XMLHttpRequest对象联系的HTTP请求
- 将该对象恢复到未初始化状态
3、AJAX操作示例
- 用户名的输入框设置onblur事件,触发用户名校验函数validate
- validate中,先在请求发送前调用open,然后设置请求头和事件触发器onreadystatechange,再使用send发送请求
- onreadystatechange则对应一个函数,判断响应正确后执行操作
<%@page pageEncoding="utf-8" %>
<html>
<body>
<head>
<script type="text/javascript">
var xmlHttp;
//创建
function createXmlHttp() {
if(window.ActiveObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
}
//验证用户名查重(发送请求)
function validate(){
createXmlHttp();
var username = document.getElementById("username").value;
var url = "doServlet";
xmlHttp.open("POST", url, true);
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlHttp.onreadystatechange = callback;
xmlHttp.send("username=" + username);
}
//处理
function callback() {
if(xmlHttp.readyState == 4) {
if(xmlHttp.status == 200) {
var result = xmlHttp.responseXML.getElementsByTagName("result")[0].firstChild.data;
document.getElementById("message").innerHTML = result;
} else {
document.getElementById("message").innerHTML = xmlHttp.status + ":" + xmlHttp.statusText;
}
}
}
</script>
</head>
<h2>Hello World!</h2>
<div id="message"></div>
用户名:<input type="text" id="username" name="username" value="" onblur="validate()"><br>
密码:<input type="password" id="password" name="password" value=""><br>
</body>
</html>
<%@page pageEncoding="utf-8" %>
<html>
<body>
<head>
<script type="text/javascript">
var xmlHttp;
//创建
function createXmlHttp() {
if(window.ActiveObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
}
//验证用户名查重(发送请求)
function validate(){
createXmlHttp();
var username = document.getElementById("username").value;
var url = "doServlet";
xmlHttp.open("POST", url, true);
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlHttp.onreadystatechange = callback;
xmlHttp.send("username=" + username);
}
//处理
function callback() {
if(xmlHttp.readyState == 4) {
if(xmlHttp.status == 200) {
var result = xmlHttp.responseXML.getElementsByTagName("result")[0].firstChild.data;
document.getElementById("message").innerHTML = result;
} else {
document.getElementById("message").innerHTML = xmlHttp.status + ":" + xmlHttp.statusText;
}
}
}
</script>
</head>
<h2>Hello World!</h2>
<div id="message"></div>
用户名:<input type="text" id="username" name="username" value="" onblur="validate()"><br>
密码:<input type="password" id="password" name="password" value=""><br>
</body>
</html>
public class MyServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("doGet1() running...");
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("doPost() running...");
String[] usernames = {"zhangsan", "lisi", "wangwu", "zhaoliu"};
String username = request.getParameter("username");
String result = "用户名可用";
if (Arrays.asList(usernames).contains(username)) {
result = "用户名已存在";
}
response.setHeader("Cache-Control", "no-cache");
response.setCharacterEncoding("UTF-8");
PrintWriter out = response.getWriter();
out.println("<?xml version=\"1.0\" encoding=\"utf-8\" ?>");
out.println("<response>");
out.println("<result>" + result + "</result>");
out.println("</response>");
out.close();
}
}
public class MyServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("doGet1() running...");
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("doPost() running...");
String[] usernames = {"zhangsan", "lisi", "wangwu", "zhaoliu"};
String username = request.getParameter("username");
String result = "用户名可用";
if (Arrays.asList(usernames).contains(username)) {
result = "用户名已存在";
}
response.setHeader("Cache-Control", "no-cache");
response.setCharacterEncoding("UTF-8");
PrintWriter out = response.getWriter();
out.println("<?xml version=\"1.0\" encoding=\"utf-8\" ?>");
out.println("<response>");
out.println("<result>" + result + "</result>");
out.println("</response>");
out.close();
}
}
[01] AJAX的更多相关文章
- Ajax全解
jQuery确实是一个挺好的轻量级的JS框架,能帮助我们快速的开发JS应用,并在一定程度上改变了我们写JavaScript代码的习惯. 我们先来看一些简单的方法,这些方法都是对jQuery.ajax( ...
- Jquery Ajax时 error处理 之 parsererror
Jquery Ajax时 error处理 之 parsererror 01 $.ajax({ 02 type: "POST", 03 con ...
- 关于Ajax的type为post提交方式出现请求失效问题
最近碰到这样一个问题,原本一个ajax异步提交数据之前是很好的,很多系统都延用了均未出现任何问题.最近这个版本却出现ajax方式post数据不到后台程序,让我折腾了好几天.起初的ajax是这样写的: ...
- Asp.net Ajax(ashx)
主要实现 ajax分页功能 效果图 后台方法代码展示 /// <summary> /// WebAjax处理类 /// </summary> public class WebA ...
- PHP. 02®. Ajax异步处理、常见的响应状态、XMLHttpRequest对象及API、ajax的get/post方法、
异步对象 a)创建异步对象 b)设置请求的url等参数 c) 发送请求 d)注册时间 e)在注册的事件中获取返回的内容并修改页面显示的内容 布尔类型不能直接用echo输出 常见的响应状态 Ajax概 ...
- 跨域的另一种解决方案CORS(CrossOrigin Resource Sharing)跨域资源共享
在我们日常的项目开发时使用AJAX,传统的Ajax请求只能获取在同一个域名下面的资源,但是HTML5打破了这个限制,允许Ajax发起跨域的请求.浏览器是可以发起跨域请求的,比如你可以外链一个外域的图片 ...
- HTML笔记05------AJAX
AJAX初探01 AJAX概念 概念:即"Asynchronous JavaScript And XML" 通过在后台与服务器进行少量数据交换,AJAX可以使网页实现异步更新.这意 ...
- 编程从入门到放弃(Java)
1.Java入门篇 1.1 基础入门和面向对象 1.1.1 编程基础 [01] Java语言的基本认识 [02] 类和对象 [03] 类的结构和创建对象 [04] 包和访问权限修饰符 [05] 利 ...
- PDF在线预览 (flexpaper+swftools+saveaspdfandxps)
1.使用SaveAsPDFandXPS将office文档转换成PDF http://www.microsoft.com/downloads/details.aspx?FamilyID=4d951911 ...
随机推荐
- 函数节流scroll,兼容火狐滚轮事件
//函数节流 var wheelTimeout; var wheelFun = function (func) { if (wheelTimeout) { return; } func(); whee ...
- Jmeter在非GUI(命令行)模式下生成测试报告
根据各大招聘网站上的需求来看,熟悉Jmeter做性能测试已经几乎成为必要条件了. 那么今天在这个给大家安利一波,怎么使用Jmeter在非GUI(命令行)模式下生成测试报告呢?? 条件准备: 1.Jme ...
- cve-list
dlink CVE-2018-17786 CVE-2018-17787 CVE-2018-17880 CVE-2018-17881 mongoose CVE-2018-10945 openwrt CV ...
- android.support不统一的问题
今天supprt28遇到的问题,由于28还是预览版,还存在一些bug 都是因为如果程序内出现不同的,support或者其他外部引用库的多个版本,Gradle在进行合并的时候会使用本地持有的,最高版本的 ...
- 洗礼灵魂,修炼python(39)--面向对象编程(9)—魔法方法表
好的,不多说,大招来了,几乎完整的魔法方法: 基本的魔法方法 Normal 0 7.8 磅 0 2 false false false EN-US ZH-CN X-NONE /* Style Defi ...
- python第八十八天----dom js
DOM操作 1. 找到标签直接查找 document.getElementById 根据ID获取一个标签 document.getElementsByName 根据name属性获取标签集合 docum ...
- 成功清除 windows2008 内部版本7601 字眼
cmd—>bcdedit -set testsigning off重启电脑就好了
- Nginx日志格式log_format详解
PS:Nginx日志相关指令主要有两条,一条是log_format,用来设置日志格式,另外一条是access_log,用来指定日志文件的存放路径.类型.缓存大小等,一般放在Nginx的默认主配置文件/ ...
- zabbix疑难之时区问题
zabbix疑难总结: 1.zabbix的web界面的时间不对.晚12个小时整 适用于:安装网上的说法来修改,但是时间仍然不对的情况 我们按照以前的网上的那些方法在配置zabbix,需要配置时区: ...
- PHP实现简单下载功能
PHP实现简单下载 PHP文件为download.php,供下载的文件为1.jpg. <?php $filename="1.jpg"; if(!file_exists($fi ...