`
tanglei198577
  • 浏览: 61370 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

Send the request by XMLHttpRequest

阅读更多

Sending request is the asynchronous operation ,here is the code of sending on the widget:

function getRequest() { 
    http_request = false;
    if(window.XMLHttpRequest)
    {
        http_request = new XMLHttpRequest();//create a new XMLHttpRequest()
        if (http_request.overrideMimeType)
        {//set MIME type
            http_request.overrideMimeType("text/xml");
            DEBUG("dDisp", "sendRequest","http_request is XMLHttpRequest!");
        }

    }
    else if(window.ActiveXObject)
    {
        try
        {
            http_request = new ActiveXObject("MSXml2.XMLHTTP");
            DEBUG("dDisp", "sendRequest","http_request is MSXml2.XMLHTTP!");
        }
        catch(e)
        {
            try
            {
                http_request = new ActiveXObject("Microsoft.XMLHTTP");
                DEBUG("dDisp", "sendRequest","http_request is Microsoft.XMLHTTP!");
            }
            catch(e)
            {
              DEBUG("dDisp", "sendRequest","http_request is not match!");}
            }
    }
    if(!http_request)
    {
        DEBUG("dDisp","sendRequest","Can't create XMLHttpRequest object "+http_request);
        return false; 
    }
   return http_request; 
}

/**
* send the request
*/    
function getResponseText(){
	
    DEBUG("dDisp","sendRequest","Start to open XMLHttpRequest ");
    var vurl = document.getElementById("serverUrl").value;
    DEBUG("dDisp", "GetResponseText","Input URL is: " + vurl); 
    DEBUG("dDisp","sendRequest","Start to open XMLHttpRequest ");
     	  try {
		 http_request = new XMLHttpRequest();
		 http_request.open("post",vurl,true);
 		 http_request.onreadystatechange = function(){//callback function
		if (http_request.readyState==4){
                           DEBUG("dDisp", "ResponseData", http_request.status+"-"+http_request.readyState); 
 			   DEBUG("dDisp", "getResponseHeader", http_request.getResponseHeader("Content-Type")); 
                           DEBUG("dDisp", "getResponseText", http_request.responseText); 
			}
		}
		 http_request.setRequestHeader("Content-Type", "text/xml")
		 http_request.setRequestHeader("charset", "GBK");        
		 http_request.setRequestHeader("Widget-IMEI", "102");        
		 http_request.setRequestHeader("Widget-Timeout", "20");  
                 http_request.setRequestHeader("Widget-Action","Report"); 

                 //reportXml content
                 var reportXml = "<WidgetScriptResultResp>";
		 reportXml += i;
     		 reportXml += "</WidgetScriptResultResp>";
                 DEBUG("dDisp", "Loop:", i);
		 http_request.send(reportXml);				
	      }
	  catch (e) {
	  	       DEBUG("dDisp","sendRequest","Failed to open XMLHttpRequest ");
		       break;
		     }	
	}
    DEBUG("dDisp","sendRequest","Finished!");
}

 onreadystatechange() is the callback function of XMLHttpRequest,you can hanld the response of web service. readyState :0--before the open();1--before the send();2--request have been sent.3--request are handling with.4--request have been done.

0
0
分享到:
评论

相关推荐

    实例讲解用法原生JavaScript处理AJAX恳求的方法_.docx

    return function() { throw new Error("AJAX is not supported by this browser"); }; } } ``` 2. **封装请求方法** - 接下来,我们定义一个`request`方法来处理具体的请求逻辑。 ```javascript function ...

    Ajax-Axios的快速入门

    source.cancel('Operation cancelled by the user.'); ``` **6. 批量请求** 使用`axios.all()`可以并发处理多个请求,而`axios.spread()`可以将批量请求的结果拆分。 ```javascript axios.all([request1, request...

    jquery-1.1.3 效率提高800%

    // the options for this ajax request }返回值: XMLHttpRequest 使用GET请求一个页面。 这是向服务器发送get请求的简单方法。它可以指定一个回调函数,在请求完成后执行(只有在请求成功时)。如果还...

    Ajax用户注册判断用户名是否存在

    user = User.query.filter_by(username=username).first() if user: return jsonify(available=False) else: return jsonify(available=True) if __name__ == '__main__': app.run() ``` 这里假设有一个...

    .net ajax示例

    * add by zhaoyue * 2009-04-14 */ var xmlHttp ; var isTrue=false ; function createXMLHttpRequest(){ if(window.ActiveXObject){ xmlHttp=new ActiveXObject("Microsoft.XMLHTTP") ; }else if(window....

    实战Dojo工具包

    request.send(); ``` 此外,Dojo 还支持使用XMLHttpRequest来进行更细粒度的控制,如发送特定的HTTP头或处理二进制数据。 ##### 拖放操作 Dojo 的拖放功能 (`dojo.dnd`) 提供了一个易于使用的API来实现拖放交互。...

Global site tag (gtag.js) - Google Analytics