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.
分享到:
相关推荐
return function() { throw new Error("AJAX is not supported by this browser"); }; } } ``` 2. **封装请求方法** - 接下来,我们定义一个`request`方法来处理具体的请求逻辑。 ```javascript function ...
source.cancel('Operation cancelled by the user.'); ``` **6. 批量请求** 使用`axios.all()`可以并发处理多个请求,而`axios.spread()`可以将批量请求的结果拆分。 ```javascript axios.all([request1, request...
// the options for this ajax request }返回值: XMLHttpRequest 使用GET请求一个页面。 这是向服务器发送get请求的简单方法。它可以指定一个回调函数,在请求完成后执行(只有在请求成功时)。如果还...
user = User.query.filter_by(username=username).first() if user: return jsonify(available=False) else: return jsonify(available=True) if __name__ == '__main__': app.run() ``` 这里假设有一个...
* add by zhaoyue * 2009-04-14 */ var xmlHttp ; var isTrue=false ; function createXMLHttpRequest(){ if(window.ActiveXObject){ xmlHttp=new ActiveXObject("Microsoft.XMLHTTP") ; }else if(window....
request.send(); ``` 此外,Dojo 还支持使用XMLHttpRequest来进行更细粒度的控制,如发送特定的HTTP头或处理二进制数据。 ##### 拖放操作 Dojo 的拖放功能 (`dojo.dnd`) 提供了一个易于使用的API来实现拖放交互。...