[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 ...
随机推荐
- ES6学习之关键字
前言:什么是ES6?ECMAScript 6(简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.其中相比较于ES5新增了诸多的特性,并且ES6可转换为ES5的语法.- ...
- CSS 中的 BFC,IFC,GFC和FFC
原文网址:http://www.cnblogs.com/dingyufenglian/p/4845477.html What‘s FC? 一定不是KFC,FC的全称是:Formatting Conte ...
- 关于html5中的 网页图标问题
在html5 中 设置网页图标的语句<link rel="icon" type="image/x-icon" href="favicon.ico ...
- JS中的三种循环
三种循环1.while 2.do while 3.for 1.while: 语法结构:while(条件){代码块:改变条件} 步骤:1.初始化变量 2.判断条件 3.执行代码块 4.改变初始条 ...
- docker 安装软件
Docker Docker官方网址: https://docs.docker.com/ 英文地址 Docker中文网址: http://www.docker.org.cn/ 中文地址 Docker是 ...
- struts2文件上传大小限制问题小结(引用)
最后解决办法: 页面js控制上传文件的大小,在页面进行控制.如下代码 inputs是所有文本上传input DOM //名称信息 var nameStr=''; //大小信息 var sizeStr= ...
- SD从零开始65 框架协议(Outline Agreement)
SD从零开始65 框架协议(Outline Agreement) 合同-销售凭证类型Contracts-Sales Document Types 框架协议在几乎所有的业务处理中都扮演重要的角色:客户和 ...
- JavaScript日期排序
//日期排序 function sortDownDate(a, b) { return Date.parse(a.received) - Date.parse(b.received); } funct ...
- JavaScript按纯数字排序
直接上代码: var arr=[ {name:"张散步",age:"23",sports:"篮球",number:"23112 ...
- Python之随机森林实战
代码实现: # -*- coding: utf-8 -*- """ Created on Tue Sep 4 09:38:57 2018 @author: zhen &q ...