Ajax基础

XMLHttpRequest的几个方法和属性

● open():建立到服务器的新请求。

● send():向服务器发送请求。

● abort():退出当前请求。

● readyState:提供当前 HTML 的就绪状态。

● responseText:服务器返回的请求响应文本。

创建新的 XMLHttpRequest 对象

var request = new XMLHttpRequest();
javascript 不要求指定变量类型
在 Java 语言中可能需要这样(创建 XMLHttpRequest 的 Java 伪代码)
XMlHttpRequest request = new XMLHttpRequest();

错误处理

1:创建一个新的变量request并赋值false。后面将使用false作为判定条件,它表示还没创建XMLHttpRequest对象
2:增加try/catch
1)尝试创建XMLHttpRequst对象。
2)如果失败(catch(failed))则保证request的值仍然为false
3:检查request是否仍为false(如果一切正常就不会是fasle)。
4:如果出现问题(request是false)则使用javascript警告通知用户出现了问题。
var request = false;
try{
    request = new XMLHttpRequest();
}catch(failed){
	request = false;
}
if(!request)
    alert("Error initializingXMLHttpRequest!");
增加对 Microsoft 浏览器的支持
1:创建一个新变量request并赋值false。使用false作为判断条件,他表示还没有创建XMLHttpRequest对象。
2:增加try/catch
1)尝试使用较新版本的Microsoft浏览器创建Microsoft兼容对象(Msxml2.XMLHttp)。
2)如果失败(catch(othermicrosoft))尝试使用较老版本的Microsoft浏览器创建Microsoft兼容的对象(Microsoft.XMLHttp).
3)如果失败(catch(failed))则保证request的值仍然为false
3:检查request是否仍然为false(如果一切顺利就不会是false)。
4:如果出现问题(requestfalse)则使用javascript警告通知用户出现问题。
var request = false;
try{
    request = XMLHttpRequest();
}catch(trymicrosoft){
	try{
        request = new ActiveXObject("Msxml2.XMLHTTP");
    }catch(othermicrosoft){
        try{
            request = new ActiveXObiect("Microsoft.XMLHTTP");
        }catch(failed){
            request = false;
        }
    }
}
if(!request)
    alert("Error initializing XMLHttpRequest!");
将 XMLHttpRequest 创建代码移动到方法中
var request = flase;
function createRequest() {
 try {
 	request = new XMLHttpRequest();
 } catch (trymicrosoft) {
     try {
     	request = new ActiveXObject("Msxml2.XMLHTTP");
     } catch (othermicrosoft) {
         try {
         	request = new ActiveXObject("Microsoft.XMLHTTP");
         } catch (failed) {
         	request = false;
         }
     }
 }
 if (!request)
 	alert("Error initializing XMLHttpRequest!");
}
function getCustomerInfo() {
 createRequest();
 // Do something with the request variable
}

用 XMLHttpRequest 发送请求

得到请求对象之后就可以进入请求/响应循环了。记住,XMLHttpRequest 惟一的目的是让您发送请求和接

收响应。其他一切都是 javascript、CSS 或页面中其他代码的工作:改变用户界面、切换图像、解释服务器

返回的数据。

设置服务器 URL

首先要确定连接的服务器的 URL。这并不是 Ajax 的特殊要求,但仍然是建立连接所必需的,

建立请求 URL
<body>
    <form action="POST">
     <p>Enter your phone number:
            <!--getCustomerInfo() 方法。该方法取得电话号码并构造存储在 url 变量中的 URL 字符串。-->
         <input type="text" size="14" name="phone" id="phone" onChange="getCustomerInfo();" />
     </p>
    </form>
</body>
<script>
    var request = false;
    try{
        request = XMLHttpRequest();
    }catch(trymicrosoft){
        try{
            request = new ActiveXObject("Msxml2.XMLHTTP");
        }catch(othermicrosoft){
            try{
                request = new ActiveXObiect("Microsoft.XMLHTTP");
            }catch(failed){
                request = false;
            }
        }
    }
    if(!request)
        alert("Error initializing XMLHttpRequest!");
    function getCustomerInfo() {
        var phone = document.getElementById("phone").value;
        /*
        *escape() 方法,它用于转义不能用明文正确发送的任何字符。比如,电话号码中的空格
将被转换成字符 %20,从而能够在 URL 中传递这些字符。
  *可以根据需要添加任意多个参数。比如,如果需要增加另一个参数,只需要将其附加到 URL 中并用 
“与”(&)字符分开 [第一个参数用问号(?)和脚本名分开]	
  */
        var url = "/cgi-local/lookupCustomer.php?phone=" + escape(phone);
    }
</script>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值