日期:2014-05-16 浏览次数:20594 次
onload=function(){
//这个是为了让第一个输入框在打开时就获得焦点
document.getElementsByTagName("input")[0].focus();
}
//onload之外,这是创建AJAX的函数
function create_ajax(){
var request=null
try{
request=new XMLHttpRequest();
if(request.overrideMimeType){
request.overrideMiMeType("text/xml");
}
}catch(e){
try{
request=new ActiveXObject("Msxml2.XMLHTTP");
}catch(e){
request=new ActiveXObject("Microsoft.XMLHTTP");
}
}
return request;
}
//这个地方创建AJAX对象
var handler=create_ajax();
//这个是当HTML中出发onblur事件后,调用的函数onblur="q(this,this.value);"
function q(obj,value){
url="server.php?username="+value;
handler.open("get",url,true);
//实际测试的时候,q()这个函数调用了,但是onreadystatechange这个函数在CHROME下没被执行
handler.onreadystatechange=function(){
//**************************
//在CHROME下,进不去这个IF语句!!包括onreadystatechange也没进来!!
//**************************
if(handler.readyState==4){
if(handler.status==200){
if(typeof(obj.nextSibling.textContent)=="string"){
obj.nextSibling.textContent=handler.responseText;
}else{
obj.nextSibling.innerHTML=handler.responseText;
}
}else{
return;
}
}else{
return;
}
}
handler.send(null);
}
//这个是当出发onfocus事件后触发的,onfocus="r(this,"somestring");"
function r(obj,value){
obj.nextSibling.innerHTML='<font color="orange">'+value+'</font>';
return false;
}
<!Doctype html>
<html>
<head>
<script type="text/javascript" src="./js/ajax_neo.js"></script>
</head>
<body>
...
<!-- 输入框的获取焦点和失去焦点事件 -->
<input type="text" name="username" onfocus="r(this,'somestring');" onblur="q(this,this.value);" />
...
</body>
</html>
if (request.overrideMimeType) {
//request.overrideMiMeType("text/xml");//大小写没区分
request.overrideMimeType("text/xml");