html关于ajax创建XMLHttpRequest对象
为什么
alert 一下 就可以使用
不 alert 的话 什么提示都没有
代码 如下
创建 对象
function getXmlhttp(method,url,async,contents){
var xmlhttp;
if(window.XMLHttpRequest){
xmlhttp=new XMLHttpRequest();
}
if(window.ActiveXObject){
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
if(!xmlhttp){
xmlhttp=new ActiveXObject("Msxml2.XMLHTTP");
}else{
alert("浏览器版本太低,请更换浏览器");
return;
}
}
xmlhttp.open(method,url,async);
if(method=='post'||method=='POST'){
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
}
xmlhttp.send(contents);
return xmlhttp;
}
function onreadystatechange(xmlhttp){
if(xmlhttp.readyState==4){
if(xmlhttp.status==200){
return true;
}
}
return false;
}
测试代码
<%@ page language="java" contentType="text/html; charset=UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<script type="text/javascript" src="jQuery/jquery-1.9.1.js"></script>
<script src="jQuery/getXMLHttpRequest.js"></script>
<script>
window.onload = function() {
$("#bt1").click(function() {
var xmlhttp= getXmlhttp("get","ajax1.action",true,null);
// alert(xmlhttp);
if (onreadystatechange(xmlhttp)) {
alert("ok");
$("#d1").html(xmlhttp.responseText);
} else {
alert("no");
}
});
}
</script>
</head>
<body>
<div id="d1"
style="border: 1px solid red; width: 300px; height: 300px;"></div>
<button id="bt1">点我试试</button>
</body>
</html>
后台serlet
package cn.yubai.ajax1;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(urlPatterns = "/ajax1.action")
public class AjaxServlet1 extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
resp.setContentType("text/html;charset=UTF-8");
PrintWriter out = resp.getWriter();
out.print("点我干啥");
}
}