码迷,mamicode.com
首页 > 编程语言 > 详细

【转】javascript的ajax请求正确写法(兼容多浏览器)

时间:2015-01-02 18:45:55      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:

     function createXMLHttp() {    
        var XmlHttp;
        if (window.ActiveXObject)
        {
            var arr=["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.5.0", "MSXML2.XMLHttp.4.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp","Microsoft.XMLHttp"];
            for(var i=0;i<arr.length;i++) {
                try {
                    XmlHttp = new ActiveXObject(arr[i]);
                    return XmlHttp;
                }
                catch(error) { }
            }
        } else {
            try {
                XmlHttp=new XMLHttpRequest();
                return XmlHttp;
            }
            catch(otherError) { }
        } 
    } 
    
    function xmlPost() {        
       var xmlHttp = createXMLHttp();
       var url= ‘TicketHandler.ashx?t=‘ + new Date();
     xmlHttp.open(‘GET‘,url,true);     
     xmlHttp.onreadystatechange = function() {      
       if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
            var result = xmlHttp.responseText;
            if (result && result.length > 0){
                result = result.split(‘,‘);
                var left;
                for (var i=0; i<result.length; i++){
                    left = document.getElementById(‘left_‘ + result[i].split(‘:‘)[0]);
                    if (left){
                        left.innerHTML = result[i].split(‘:‘)[1];
                    }
                }
            }
         }
       }
       xmlHttp.send(‘‘);
     }

很多人经常遇到在Firefox浏览器下不work的时候,请注意上述代码的大小写,比如:

xmlHttp.readyState == 4 && xmlHttp.status == 200 和 xmlHttp.responseText ,如果大小写有误,那么在Firefox浏览器下很可能会出现undefine的错误。

【转】javascript的ajax请求正确写法(兼容多浏览器)

标签:

原文地址:http://www.cnblogs.com/Blessing/p/4198657.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!