Search completed in 1.60 seconds.
  
   
    Using XMLHttpRequest - Web APIs
    
 in this guide, we'll take a look at how to use 
xmlhttprequest to issue http requests in order to exchange data between the web site and a server.
... examples of both common and more obscure use cases for 
xmlhttprequest are included.
...  to send an http request, create an 
xmlhttprequest object, open a url, and send the request.
...And 42 more matches
   
 
   
    XMLHttpRequest - Web APIs
    
 xmlhttprequest (xhr) objects are used to interact with servers.
...
xmlhttprequest is used heavily in ajax programming.
...t="50" fill="#fff" stroke="#d4dde4" stroke-width="2px" /><text  x="56" y="30" font-size="12px" font-family="consolas,monaco,andale mono,monospace" fill="#4d4e53" text-anchor="middle" alignment-baseline="middle">eventtarget</text></a><polyline points="111,25  121,20  121,30  111,25" stroke="#d4dde4" fill="none"/><line x1="121" y1="25" x2="151" y2="25" stroke="#d4dde4"/><a xlink:href="/docs/web/api/
xmlhttprequesteventtarget" target="_top"><rect x="151" y="1" width="250" height="50" fill="#fff" stroke="#d4dde4" stroke-width="2px" /><text  x="276" y="30" font-size="12px" font-family="consolas,monaco,andale mono,monospace" fill="#4d4e53" text-anchor="middle" alignment-baseline="middle">
xmlhttprequesteventtarget</text></a><polyline points="401,25  411,20  411,30  401,25" stroke="#d4dde4" fill="none"/><line x1...
...And 39 more matches
   
 
   
    HTML in XMLHttpRequest - Web APIs
    
 the w3c 
xmlhttprequest specification adds html parsing support to 
xmlhttprequest, which originally supported only xml parsing.
... this feature allows web apps to obtain an html resource as a parsed dom using 
xmlhttprequest.
...  to get an overview of how to use 
xmlhttprequest in general, see using 
xmlhttprequest.
...And 12 more matches
   
 
   
    XMLHttpRequestEventTarget - Web APIs
    
 xmlhttprequesteventtarget is the interface that describes the event handlers you can implement in an object that will handle events for an 
xmlhttprequest.
...t="50" fill="#fff" stroke="#d4dde4" stroke-width="2px" /><text  x="56" y="30" font-size="12px" font-family="consolas,monaco,andale mono,monospace" fill="#4d4e53" text-anchor="middle" alignment-baseline="middle">eventtarget</text></a><polyline points="111,25  121,20  121,30  111,25" stroke="#d4dde4" fill="none"/><line x1="121" y1="25" x2="151" y2="25" stroke="#d4dde4"/><a xlink:href="/docs/web/api/
xmlhttprequesteventtarget" target="_top"><rect x="151" y="1" width="250" height="50" fill="#f4f7f8" stroke="#d4dde4" stroke-width="2px" /><text  x="276" y="30" font-size="12px" font-family="consolas,monaco,andale mono,monospace" fill="#4d4e53" text-anchor="middle" alignment-baseline="middle">
xmlhttprequesteventtarget</text></a></svg></div>     a:hover text { fill: #0095dd; pointer-events: all;}       properties...
...   	
xmlhttprequesteventtarget.onabort 	contains the function to call when a request is aborted and the abort event is received by this object.
...And 7 more matches
   
 
   
    nsIXMLHttpRequest
    
 nsi
xmlhttprequest along with nsijs
xmlhttprequest and nsi
xmlhttprequesteventtarget are mozilla's implementation details of the dom 
xmlhttprequest object.
...  note: if you're a web developer or a mozilla add-on developer, please refer to the 
xmlhttprequest documentation instead.
... the interface definition: //github.com/realityripple/uxp/blob/master/dom/xhr/nsi
xmlhttprequest.idl  elevated privileges  as mentioned in the "non-standard properties" the property of channel was read-only.
...And 4 more matches
   
 
   
    XMLHttpRequest.responseType - Web APIs
    
 the 
xmlhttprequest property responsetype is an enumerated string value specifying the type of data contained in the response.
... syntax  var type = 
xmlhttprequest.responsetype;  
xmlhttprequest.responsetype = type;  value  a string taken from the 
xmlhttprequestresponsetype enum which specifies what type of data the response contains.
...see html in 
xmlhttprequest to learn more about using xhr to fetch html content.
...And 4 more matches
   
 
   
    XMLHttpRequest.send() - Web APIs
    
 the 
xmlhttprequest method send() sends the request to the server.
... syntax  
xmlhttprequest.send(body)   parameters    body optional  a body of data to be sent in the xhr request.
...  an 
xmlhttprequestbodyinit, which per the fetch spec can be a blob, buffersource, formdata, urlsearchparams, or usvstring object.
...And 4 more matches
   
 
   
    XMLHttpRequest() - Web APIs
    
           the 
xmlhttprequest() constructor creates a new 
xmlhttprequest.
...  for details about how to use 
xmlhttprequest, see using 
xmlhttprequest.
...  syntax  const request = new 
xmlhttprequest();   parameters  none.
...And 3 more matches
   
 
   
    XMLHttpRequest.getAllResponseHeaders() - Web APIs
    
 the 
xmlhttprequest method getallresponseheaders() returns all the response headers, separated by crlf, as a string, or returns null if no response has been received.
...  syntax  var headers = 
xmlhttprequest.getallresponseheaders();  parameters  none.
...  example  this example examines the headers in the request's readystatechange event handler, 
xmlhttprequest.onreadystatechange.
...And 2 more matches
   
 
   
    XMLHttpRequest.overrideMimeType() - Web APIs
    
           the 
xmlhttprequest method overridemimetype() specifies a mime type other than the one provided by the server to be used instead when interpreting the data being transferred in a request.
... syntax  
xmlhttprequest.overridemimetype(mimetype)  parameters    mimetype  a domstring specifying the mime type to use instead of the one specified by the server.
... if the server doesn't specify a type, 
xmlhttprequest assumes "text/xml".
...And 2 more matches
   
 
   
    XMLHttpRequest.response - Web APIs
    
 the 
xmlhttprequest response property returns the response's body content as an arraybuffer, blob, document, javascript object, or domstring, depending on the value of the request's responsetype property.
...  syntax  var body = 
xmlhttprequest.response;   value  an appropriate object based on the value of responsetype.
...see html in 
xmlhttprequest to learn more about using xhr to fetch html content.
...And 2 more matches
   
 
   
    XMLHttpRequest.responseText - Web APIs
    
             the read-only 
xmlhttprequest property responsetext returns the text received from a server following a request being sent.
...  syntax  var resulttext = 
xmlhttprequest.responsetext;  value  a domstring which contains either the textual data received using the 
xmlhttprequest or null if the request failed or "" if the request has not yet been sent by calling send().
... you know the entire content has been received when the value of readystate becomes 
xmlhttprequest.done (4), and status becomes 200 ("ok").
...And 2 more matches
   
 
   
    XMLHttpRequest.timeout - Web APIs
    
 the 
xmlhttprequest.timeout property is an unsigned long representing the number of milliseconds a request can take before automatically being terminated.
...timeout shouldn't be used for synchronous 
xmlhttprequests requests used in a document environment or it will throw an invalidaccesserror exception.
... example  var xhr = new 
xmlhttprequest(); xhr.open('get', '/server', true);  xhr.timeout = 2000; // time in milliseconds  xhr.onload = function () {   // request finished.
...And 2 more matches
   
 
   
   
    XMLHttpRequest.abort() - Web APIs
    
 the 
xmlhttprequest.abort() method aborts the request if it has already been sent.
... when a request is aborted, its readystate is changed to 
xmlhttprequest.unsent (0) and the request's status code is set to 0.
...  syntax  
xmlhttprequest.abort()  parameters  none.
... var xhr = new 
xmlhttprequest(),     method = "get",     url = "https://developer.mozilla.org/"; xhr.open(method, url, true);  xhr.send();  if (oh_noes_we_need_to_cancel_right_now_or_else) {   xhr.abort(); }   specifications           specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
  
   
    XMLHttpRequest.getResponseHeader() - Web APIs
    
 the 
xmlhttprequest method getresponseheader() returns the string containing the text of a particular header's value.
... syntax  var myheader = 
xmlhttprequest.getresponseheader(headername);  parameters    headername  a bytestring indicating the name of the header you want to return the text value of.
...if the content-type isn't the desired value, the 
xmlhttprequest is canceled by calling abort().
...  var client = new 
xmlhttprequest(); client.open("get", "unicorns-are-teh-awesome.txt", true); client.send();  client.onreadystatechange = function() {   if(this.readystate == this.headers_received) {     var contenttype = client.getresponseheader("content-type");     if (contenttype != my_expected_type) {       client.abort();     }   } }  specifications           specification    status    comment              
xmlhttprequestthe definition of 'getresponseheader()' in that specification.
   
 
   
    XMLHttpRequest.onreadystatechange - Web APIs
    
the 
xmlhttprequest.onreadystatechange property contains the event handler to be called when the readystatechange event is fired, that is every time the readystate property of the 
xmlhttprequest changes.
...  syntax  
xmlhttprequest.onreadystatechange = callback;  values    callback is the function to be executed when the readystate changes.
...   examples  const xhr = new 
xmlhttprequest(),     method = "get",     url = "https://developer.mozilla.org/";  xhr.open(method, url, true); xhr.onreadystatechange = function () {   // in local files, status is 0 upon success in mozilla firefox   if(xhr.readystate === 
xmlhttprequest.done) {     var status = xhr.status;     if (status === 0 || (status >= 200 && status < 400)) {       // the request has been completed successfully       console.log(xhr.responsetext);     } else {       // oh no!
...    }   } }; xhr.send();  specifications           specification    status    comment              
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequest.readyState - Web APIs
    
 the 
xmlhttprequest.readystate property returns the state an 
xmlhttprequest client is in.
...         unsent  the 
xmlhttprequest client has been created, but the open() method hasn't been called yet.
...  example  var xhr = new 
xmlhttprequest(); console.log('unsent', xhr.readystate); // readystate will be 0  xhr.open('get', '/api', true); console.log('opened', xhr.readystate); // readystate will be 1  xhr.onprogress = function () {     console.log('loading', xhr.readystate); // readystate will be 3 };  xhr.onload = function () {     console.log('done', xhr.readystate); // readystate will be 4 };  xhr.send(null);   specifications      ...
...     specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequest.responseXML - Web APIs
    
 the 
xmlhttprequest.responsexml read-only property returns a document containing the html or xml retrieved by the request; or null if the request was unsuccessful, has not yet been sent, or if the data can't be parsed as xml or html.
... if the server doesn't specify the content-type as "text/xml" or "application/xml", you can use 
xmlhttprequest.overridemimetype() to parse it as xml anyway.
... syntax  var data = 
xmlhttprequest.responsexml;   value  a document from parsing the xml or html received using 
xmlhttprequest, or null if no data was received or if the data is not xml/html.
...  example  var xhr = new 
xmlhttprequest; xhr.open('get', '/server');  // if specified, responsetype must be empty string or "document" xhr.responsetype = 'document';  // force the response to be parsed as xml xhr.overridemimetype('text/xml');  xhr.onload = function () {   if (xhr.readystate === xhr.done && xhr.status === 200) {     console.log(xhr.response, xhr.responsexml);   } };  xhr.send();  specifications           specification    status    comment              
xmlhttprequestthe definition of 'responsexml' in that specification.
   
 
   
    XMLHttpRequest.sendAsBinary() - Web APIs
    
 the obsolete 
xmlhttprequest method sendasbinary() is a variant of the send() method that sends binary data.
...  syntax  
xmlhttprequest.sendasbinary(binarystring);   parameters    binarystring  a domstring which encodes the binary content to be sent.
... /*\ |*| |*|  :: 
xmlhttprequest.prototype.sendasbinary() polyfill :: |*| |*|  https://developer.mozilla.org/docs/dom/
xmlhttprequest#sendasbinary() |*| \*/  if (!
xmlhttprequest.prototype.sendasbinary) {   
xmlhttprequest.prototype.sendasbinary = function (sdata) {     var nbytes = sdata.length, ui8data = new uint8array(nbytes);     for (var nidx = 0; nidx < nbytes; nidx++) {       ui8data[nidx] = sdata.charcodeat(nidx) & 0xff;     }     /* ...
...however, on google chrome, when you try to send an arraybuffer, the following warning message will appear: arraybuffer is deprecated in 
xmlhttprequest.send().
   
 
   
    XMLHttpRequest.upload - Web APIs
    
 the 
xmlhttprequest upload property returns an 
xmlhttprequestupload object that can be observed to monitor an upload's progress.
... it is an opaque object, but because it's also an 
xmlhttprequesteventtarget, event listeners can be attached to track its process.
...         timeout    ontimeout    the upload timed out because a reply did not arrive within the time interval specified by the 
xmlhttprequest.timeout.
...       specifications           specification    status    comment              
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequest.withCredentials - Web APIs
    
 the 
xmlhttprequest.withcredentials property is a boolean that indicates whether or not cross-site access-control requests should be made using credentials such as cookies, authorization headers or tls client certificates.
...
xmlhttprequest from a different domain cannot set cookie values for their own domain unless withcredentials is set to true before making the request.
...   note: 
xmlhttprequest responses from a different domain cannot set cookie values for their own domain unless withcredentials is set to true before making the request, regardless of access-control- header values.
...    example  var xhr = new 
xmlhttprequest(); xhr.open('get', 'http://example.com/', true); xhr.withcredentials = true; xhr.send(null);  specifications           specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequestEventTarget.onabort - Web APIs
    
 the 
xmlhttprequesteventtarget.onabort is the function called when an 
xmlhttprequest transaction is aborted, such as when the 
xmlhttprequest.abort() function is called.
...  syntax  
xmlhttprequest.onabort = callback;  values   	callback is the function to be executed when the transaction is aborted.
...   example  var xmlhttp = new 
xmlhttprequest(),   method = 'get',   url = 'https://developer.mozilla.org/';  xmlhttp.open(method, url, true); xmlhttp.onabort = function () {   console.log('** the request was aborted'); }; xmlhttp.send(); //..
... xmlhttp.abort(); // this will invoke our onabort handler above   specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequest 			living standard 			whatwg living standard 		 	   ...
   
 
   
    XMLHttpRequestEventTarget.onload - Web APIs
    
 the 
xmlhttprequesteventtarget.onload is the function called when an 
xmlhttprequest transaction completes successfully.
...  syntax  
xmlhttprequest.onload = callback;  values   	callback is the function to be executed when the request completes successfully.
...the context) is the same 
xmlhttprequest this callback is related to.
...   example  var xmlhttp = new 
xmlhttprequest(),   method = 'get',   url = 'https://developer.mozilla.org/';  xmlhttp.open(method, url, true); xmlhttp.onload = function () {   // do something with the retrieved data ( found in xmlhttp.response ) }; xmlhttp.send();   specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequest 			living standard 			whatwg living standard 		 	   ...
   
 
   
    XMLHttpRequestResponseType - Web APIs
    
 the 
xmlhttprequestresponsetype type is an enumerated set of strings which are used to specify the type of data contained in the response of an 
xmlhttprequest.
...see html in 
xmlhttprequest to learn more about using xhr to fetch html content.
...  deprecated values    moz-chunked-arraybuffer      a firefox-only value which instructs 
xmlhttprequest to deliver arraybuffer objects containing chunks of the incoming data.
...    specifications           specification    status    comment          
xmlhttprequest    unknown    live standard, latest version        ...
   
 
   
    How to check the security state of an XMLHTTPRequest over SSL - Web APIs
    
        here is a an example javascript function that prints the security details of an 
xmlhttprequest sent over ssl.
... the function is passed the channel property of an 
xmlhttprequest to extract the following information:   was the connection secure?
...organization + "\n");         dump("\tsha1 fingerprint = " + cert.sha1fingerprint + "\n");               var validity = cert.validity.queryinterface(ci.nsix509certvalidity);       dump("\tvalid from " + validity.notbeforegmt + "\n");       dump("\tvalid until " + validity.notaftergmt + "\n");     }   } catch(err) {     alert(err);   } }  function test(url) {   var req = cc["@mozilla.org/xmlextras/
xmlhttprequest;1"].createinstance();   req.open('get', url, true);   req.addeventlistener("error",     function(e) {       var error = createtcperrorfromfailedxhr(req);       dumpsecurityinfo(req, error);     },     false);     req.onload = function(e) {     dumpsecurityinfo(req);   };    req.send(); }  then test("https://addons.mozilla.org");  produced the following output in my console: connection status:    ...
   
 
   
    Using XMLHttpRequest in IE6 - Web APIs
    
 xmlhttprequest was first introduced by microsoft in internet explorer 5.0 as an activex control.
... however, in ie7 and other browsers 
xmlhttprequest is a native javascript object.
... in all modern browsers, you can create a new 
xmlhttprequest object using the following code: var request = new 
xmlhttprequest()  however, if you need to also support internet explorer 6 and older, you need to extend your code like this: if (window.
xmlhttprequest) {     //firefox, opera, ie7, and other browsers will use the native object     var request = new 
xmlhttprequest(); } else {     //ie 5 and 6 will use the activex control     var request = new activexobject("microsoft.xmlhttp"); }  see also  using 
xmlhttprequest                                 ...
   
 
   
    XMLHttpRequest: abort event - Web APIs
    
 the abort event is fired when a request has been aborted, for example because the program called 
xmlhttprequest.abort().
...  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest: load event - Web APIs
    
 the load event is fired when an 
xmlhttprequest transaction completes successfully.
...  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest.open() - Web APIs
    
 the 
xmlhttprequest method open() initializes a newly-created request, or re-initializes an existing one.
... syntax  
xmlhttprequest.open(method, url[, async[, user[, password]]])   parameters    method  the http request method to use, such as "get", "post", "put", "delete", etc.
...  specifications           specification    status    comment              
xmlhttprequestthe definition of 'open()' in that specification.
   
 
   
  
   
    XMLHttpRequest.setRequestHeader() - Web APIs
    
 the 
xmlhttprequest method setrequestheader() sets the value of an http request header.
...  syntax  
xmlhttprequest.setrequestheader(header, value)   parameters    header  the name of the header whose value is to be set.
... specifications           specification    status    comment          
xmlhttprequestthe definition of 'setrequestheader()' in that specification.
   
 
   
    XMLHttpRequest.status - Web APIs
    
 the read-only 
xmlhttprequest.status property returns the numerical http status code of the 
xmlhttprequest's response.
...browsers also report a status of 0 in case of 
xmlhttprequest errors.
...  example  var xhr = new 
xmlhttprequest(); console.log('unsent: ', xhr.status);  xhr.open('get', '/server'); console.log('opened: ', xhr.status);  xhr.onprogress = function () {   console.log('loading: ', xhr.status); };  xhr.onload = function () {   console.log('done: ', xhr.status); };  xhr.send();  /**  * outputs the following:  *  * unsent: 0  * opened: 0  * loading: 200  * done: 200  */   specifications           specification    status    comment              
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequest.statusText - Web APIs
    
 the read-only 
xmlhttprequest.statustext property returns a domstring containing the response's status message as returned by the http server.
... unlike 
xmlhttprequest.status which indicates a numerical status code, this property contains the text of the response status, such as "ok" or "not found".
... example  var xhr = new 
xmlhttprequest(); console.log('0 unsent', xhr.statustext);  xhr.open('get', '/server', true); console.log('1 opened', xhr.statustext);  xhr.onprogress = function () {   console.log('3 loading', xhr.statustext); };  xhr.onload = function () {   console.log('4 done', xhr.statustext); };  xhr.send(null);  /**  * outputs the following:  *  * 0 unsent  * 1 opened  * 3 loading ok  * 4 done ok  */   specifications           specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequestEventTarget.onerror - Web APIs
    
 the 
xmlhttprequesteventtarget.onerror is the function called when an 
xmlhttprequest transaction fails due to an error.
...  syntax  
xmlhttprequest.onerror = callback;  values   	callback is the function to be executed when the request fails.
...   example  var xmlhttp = new 
xmlhttprequest(),   method = 'get',   url = 'https://developer.mozilla.org/';  xmlhttp.open(method, url, true); xmlhttp.onerror = function () {   console.log("** an error occurred during the transaction"); }; xmlhttp.send();   specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequest 			living standard 			whatwg living standard 		 	   ...
   
 
   
    XMLHttpRequestEventTarget.onloadstart - Web APIs
    
 the 
xmlhttprequesteventtarget.onloadstart is the function called when an 
xmlhttprequest transaction starts transferring data.
...  syntax  
xmlhttprequest.onloadstart = callback;  values    callback is the function to be called when the transaction begins to transfer data.
...   example  var xmlhttp = new 
xmlhttprequest(),   method = 'get',   url = 'https://developer.mozilla.org/';  xmlhttp.open(method, url, true); xmlhttp.onloadstart = function () {   console.log("download underway"); }; xmlhttp.send();   specifications           specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    XMLHttpRequestEventTarget.onprogress - Web APIs
    
 the 
xmlhttprequesteventtarget.onprogress is the function called periodically with information when an 
xmlhttprequest before success completely.
...  syntax  
xmlhttprequest.onprogress = callback;  values    callback is the function to be called periodically before the request is completed.
...  
xmlhttprequest.onprogress = function (event) {   event.loaded;   event.total; };  example  var xmlhttp = new 
xmlhttprequest(),   method = 'get',   url = 'https://developer.mozilla.org/';  xmlhttp.open(method, url, true); xmlhttp.onprogress = function () {   //do something }; xmlhttp.send();   specifications           specification    status    comment          
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
    nsIXMLHttpRequestEventTarget
    
         content/base/public/nsi
xmlhttprequest.idlscriptable   this interface provides access to the event listeners used when uploading data using the 
xmlhttprequest object.
...see also  using 
xmlhttprequest xmlhttprequest nsi
xmlhttprequest nsidomprogressevent                                 ...
   
 
   
    nsIXMLHttpRequestUpload
    
         content/base/public/nsi
xmlhttprequest.idlscriptable   this interface provides access to the features needed when uploading data using nsi
xmlhttprequest.
...eamonkey 2.0)  attributes                attribute       type       description                 onabort       nsidomeventlistener                         onerror       nsidomeventlistener                         onload       nsidomeventlistener                         onloadstart       nsidomeventlistener                         onprogress       nsidomeventlistener                  see also    nsi
xmlhttprequest   nsi
xmlhttprequesteventtarget   
xmlhttprequest   using 
xmlhttprequest                                 ...
   
 
   
    XMLHttpRequest: error event - Web APIs
    
  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest: loadend event - Web APIs
    
  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest: loadstart event - Web APIs
    
  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest: progress event - Web APIs
    
  function addlisteners(xhr) {     xhr.addeventlistener('loadstart', handleevent);     xhr.addeventlistener('load', handleevent);     xhr.addeventlistener('loadend', handleevent);     xhr.addeventlistener('progress', handleevent);     xhr.addeventlistener('error', handleevent);     xhr.addeventlistener('abort', handleevent); }  function runxhr(url) {     log.textcontent = '';      const xhr = new 
xmlhttprequest();     addlisteners(xhr);     xhr.open("get", url);     xhr.send();     return xhr; }  xhrbuttonsuccess.addeventlistener('click', () => {     runxhr('https://mdn.mozillademos.org/files/16553/dgszyjnxcaipwzy.jpg'); });  xhrbuttonerror.addeventlistener('click', () => {     runxhr('https://somewhere.org/i-dont-exist'); });  xhrbuttonabort.addeventlistener('click', () => {     runxhr('https://mdn.moz...
...illademos.org/files/16553/dgszyjnxcaipwzy.jpg').abort(); });  result    specifications           specification    status    comment              
xmlhttprequest    living standard             ...
   
 
   
    XMLHttpRequest.responseURL - Web APIs
    
 the read-only 
xmlhttprequest.responseurl property returns the serialized url of the response or the empty string if the url is null.
... example  var xhr = new 
xmlhttprequest(); xhr.open('get', 'http://example.com/test', true); xhr.onload = function () {   console.log(xhr.responseurl); // http://example.com/test }; xhr.send(null);  specifications           specification    status    comment              
xmlhttprequest    living standard    whatwg living standard        ...
   
 
   
   
   
  
   
   
    XMLHttpRequest.openRequest() - Web APIs
    
       this mozilla-specific method is available only from within privileged code, and is only called from a c++ context in order to initialize an 
xmlhttprequest.
   
 
   
    XMLHttpRequest: timeout event - Web APIs
    
          bubbles    no          cancelable    no          interface    progressevent          event handler property    ontimeout        examples  const client = new 
xmlhttprequest(); client.open('get', 'http://www.example.org/example.txt'); client.ontimeout = () => {     console.error('timeout!!') };  client.send();  you could also set up the event handler using the addeventlistener() method:  client.addeventlistener('timeout', () => {     console.error("timeout!!"); });  specifications           specification    status    comment              
xmlhttprequestthe definition of 'timeout event' in that specification.
   
 
   
    Index - Web APIs
    
requests are guaranteed to be initiated before a page is unloaded and they are run to completion, without requiring a blocking request (for example 
xmlhttprequest).
...       1008     document: readystatechange event     event, reference, 
xmlhttprequest, interactive       the readystatechange event is fired when the readystate attribute of a document has changed.
...       1298     fetch api     api, experimental, fetch, landing, reference, response, 
xmlhttprequest, request       the fetch api provides an interface for fetching resources (including across the network).
...And 78 more matches
   
 
   
    Cross-Origin Resource Sharing (CORS) - HTTP
    
 an example of a cross-origin request: the front-end javascript code served from https://domain-a.com uses 
xmlhttprequest to make a request for https://domain-b.com/data.json.
...for example, 
xmlhttprequest and the fetch api follow the same-origin policy.
...modern browsers use cors in apis such as 
xmlhttprequest or fetch to mitigate the risks of cross-origin http requests.
...And 12 more matches
   
 
   
    Synchronous and asynchronous requests - Web APIs
    
        xmlhttprequest supports both synchronous and asynchronous communications.
... asynchronous request  if you use an asynchronous 
xmlhttprequest, you receive a callback when the data has been received.
... example: send a file to the console log  this is the simplest usage of asynchronous 
xmlhttprequest.
...And 11 more matches
   
 
   
    Sending forms through JavaScript - Learn web development
    
but forms can also prepare an http request to send via javascript, for example via 
xmlhttprequest.
... the 
xmlhttprequest (xhr) dom object can build http requests, send them, and retrieve their results.
... historically, 
xmlhttprequest was designed to fetch and send xml as an exchange format, which has since been superceded by json.
...And 10 more matches
   
 
   
    Getting Started - Developer guides
    
in a nutshell, it is the use of the 
xmlhttprequest object to communicate with servers.
...this is where 
xmlhttprequest comes in.
...then, mozilla, safari, and other browsers followed, implementing an 
xmlhttprequest object that supported the methods and properties of microsoft's original activex object.
...And 10 more matches
   
 
   
    Inner-browsing extending the browser navigation paradigm - Archive of obsolete content
    
an implementation can also use other transport technologies such as soap-based remote procedure calls, 
xmlhttprequest interfaces, or dom 3 load.
...this implementation uses 
xmlhttprequest.
...there are basically two steps in this process: data load: acquisition of information data acquisition can be implemented using javascript and remote procedure calls using soap-based rpc mechanism or using interfaces like 
xmlhttprequest (currently offered in netscape 7 and internet explorer 6).
...And 9 more matches
   
 
   
    Migrate apps from Internet Explorer to Mozilla - Archive of obsolete content
    
 i'll also cover nonstandard technologies, such as 
xmlhttprequest and rich text editing, that mozilla does support because no w3c equivalent existed at the time.
...it also supports some non-standard internet explorer extensions, such as 
xmlhttprequest.
... 
xmlhttprequest  internet explorer allows you to send and retrieve xml files using msxml's xmlhttp class, which is instantiated through activex using new activexobject("msxml2.xmlhttp") or new activexobject("microsoft.xmlhttp").
...And 9 more matches
   
 
   
    Sending and Receiving Binary Data - Web APIs
    
        receiving binary data using javascript typed arrays  the responsetype property of the 
xmlhttprequest object can be set to change the expected response type from the server.
... var oreq = new 
xmlhttprequest(); oreq.open("get", "/myfile.png", true); oreq.responsetype = "arraybuffer";  oreq.onload = function (oevent) {   var arraybuffer = oreq.response; // note: not oreq.responsetext   if (arraybuffer) {     var bytearray = new uint8array(arraybuffer);     for (var i = 0; i < bytearray.bytelength; i++) {       // do something with each byte in the array     }   } };  oreq.send(null);     you can also ...
...   var oreq = new 
xmlhttprequest(); oreq.open("get", "/myfile.png", true); oreq.responsetype = "blob";  oreq.onload = function(oevent) {   var blob = oreq.response;   // ...
...And 8 more matches
   
 
   
    Fetching data from the server - Learn web development
    
this seemingly small detail has had a huge impact on the performance and behavior of sites, so in this article, we'll explain the concept and look at technologies that make it possible, such as 
xmlhttprequest and the fetch api.
... this is achieved by using apis like 
xmlhttprequest or — more recently — the fetch api.
...  note: in the early days, this general technique was known as asynchronous javascript and xml (ajax), because it tended to use 
xmlhttprequest to request xml data.
...And 7 more matches
   
 
   
  
   
   
    Using files from web applications - Web APIs
    
 function fileupload(img, file) {   const reader = new filereader();   this.ctrl = createthrobber(img);   const xhr = new 
xmlhttprequest();   this.xhr = xhr;    const self = this;   this.xhr.upload.addeventlistener("progress", function(e) {         if (e.lengthcomputable) {           const percentage = math.round((e.loaded * 100) / e.total);           self.ctrl.update(percentage);         }       }, false);    xhr.upload.addeventlistener("load", function(e){           self.ctrl.update(100);           const canvas = self.ctrl.ctx.c...
...r.open("post", "http://demos.hacks.mozilla.org/paul/demos/resources/webservices/devnull.php");   xhr.overridemimetype('text/plain; charset=x-user-defined-binary');   reader.onload = function(evt) {     xhr.send(evt.target.result);   };   reader.readasbinarystring(file); }   the fileupload() function shown above creates a throbber, which is used to display progress information, and then creates an 
xmlhttprequest to handle uploading the data.
...  before actually transferring the data, several preparatory steps are taken:    the 
xmlhttprequest's upload progress listener is set to update the throbber with new percentage information so that as the upload progresses the throbber will be updated based on the latest information.
...And 5 more matches
   
 
   
    Event reference
    
		 		 			abort 			progressevent 			progress and 
xmlhttprequest 			progression has been terminated (not due to an error).
...		 		 			error 			progressevent 			progress and 
xmlhttprequest 			progression has failed.
...		 		 			load 			progressevent 			progress and 
xmlhttprequest 			progression has been successful.
...And 5 more matches
   
 
   
    Ajax - Developer guides
    
  asynchronous javascript and xml, while not a technology in itself, is a term coined in 2005 by jesse james garrett, that describes a "new" approach to using a number of existing technologies together, including html or xhtml, css, javascript, dom, xml, xslt, and most importantly the 
xmlhttprequest object.
... using the 
xmlhttprequest api  the 
xmlhttprequest api is the core of ajax.
...it will seem familiar to anyone who has used 
xmlhttprequest, but this api provides a more powerful and flexible feature set.
...And 5 more matches
   
 
   
    net/xhr - Archive of obsolete content
    
   provides access to 
xmlhttprequest functionality.
...  usage  security concerns  by default, the 
xmlhttprequest object grants full access to any protocol scheme, which means that it can be used to read from (but not write to) the host system's entire filesystem.
... threat model  the 
xmlhttprequest object can be used by an add-on to "phone home" and transmit potentially sensitive user data to third parties.
...And 4 more matches
   
 
   
    Appendix D: Loading Scripts - Archive of obsolete content
    
javascript files or urls may be loaded in this manner by first retrieving their contents into memory using an 
xmlhttprequest.
...   in addition to compile time, reading files synchronously from disk has its own overhead, and 
xmlhttprequests have significantly more overhead than native loading methods.
... const 
xmlhttprequest = components.constructor("@mozilla.org/xmlextras/
xmlhttprequest;1",                                               "nsi
xmlhttprequest",                                               "open");  function loadscript(name, context) {     // create the sandbox     let sandbox = components.utils.sandbox(context, {         sandboxprototype: context,         wantxrays: false     });      // get the caller'...
...And 4 more matches
   
 
   
    Index - Archive of obsolete content
    
       95     net/xhr            provides access to 
xmlhttprequest functionality.
...       189     html to dom     code snippets, dom, guide, html, intermediate, needsupdate       although you can now natively parse html using domparser and 
xmlhttprequest, this is a new feature that is not yet supported by all browsers in use in the wild.
...       230     displaying web content in an extension without security issues     extensions, security, 
xmlhttprequest, xul       one of the most common security issues with extensions is execution of remote code in privileged context.
...And 4 more matches
   
 
   
    XML Extras
    
 feature status           feature    status          xmlserializer    available          
xmlhttprequest    available          domparser (string and stream input source)    available          web services with soap and wsdl    no longer available from gecko 1.9/firefox 3.
...  qa and testing  there are some online tests for mainly exercising the http get method via 
xmlhttprequest.
... for 
xmlhttprequest object you can mostly rely on the microsoft 
xmlhttprequest documentation, with some caveats: all functions and property names begin with a lower case letter and the object creation is different.
...And 4 more matches
   
 
   
    Using FormData Objects - Web APIs
    
 the formdata object lets you compile a set of key/value pairs to send using 
xmlhttprequest.
...var blob = new blob([content], { type: "text/xml"});  formdata.append("webmasterfile", blob);  var request = new 
xmlhttprequest(); request.open("post", "http://foo.com/submitform.php"); request.send(formdata);   note: the fields "userfile" and "webmasterfile" both contain a file.
... this example builds a formdata instance containing values for fields named "username", "accountnum", "userfile" and "webmasterfile", then uses the 
xmlhttprequest method send() to send the form's data.
...And 4 more matches
   
 
   
    Connecting to Remote Content - Archive of obsolete content
    
  « previousnext »     using 
xmlhttprequest  xmlhttprequest is an api for transferring xml between a local script and a remote server via http.
... let url = "http://www.example.com/"; let request = components.classes["@mozilla.org/xmlextras/
xmlhttprequest;1"]               .createinstance(components.interfaces.nsi
xmlhttprequest); request.onload = function(aevent) {   window.alert("response text: " + aevent.target.responsetext); }; request.onerror = function(aevent) {    window.alert("error status: " + aevent.target.status); }; request.open("get", url, true); request.send(null);   in this example we demonstrate how to make a 
xmlhttprequest call in asynchronous mode.
... you can see that an instance of the 
xmlhttprequest class is created and it holds all functionality for making a request.
...And 3 more matches
   
 
   
    Using workers in extensions - Archive of obsolete content
    
  how this differs from previous versions  this version of the stock ticker extension moves the 
xmlhttprequest call that fetches updated stock information into a worker thread, which then passes that information back to the main body of the extension's code to update the display in the status bar.
... this demonstrates not only how to use workers in an extension, but also how to perform 
xmlhttprequest in a worker, and how workers and main thread code can pass data back and forth.
...  the worker  the worker thread's job in this example is to issue the 
xmlhttprequest calls that fetch the updated stock information.
...And 3 more matches
   
 
   
    Promises - Archive of obsolete content
    
    config.indexstats = processor.stats;      yield os.file.writeatomic(configpath, json.stringify(config),                               { tmppath: configpath + "." + math.random(),                                 encoding: "utf-8" })     timestamp = new date; });  http requests  http requests should, in nearly all circumstances, be made via the standard 
xmlhttprequest api.
...moreover, many third-party wrappers for the 
xmlhttprequest api now support promises out of the box.
...    let resp = yield new promise((resolve, reject) => {         let xhr = new 
xmlhttprequest;         xhr.onload = resolve;         xhr.onerror = reject;         xhr.open("get", dataurl);         xhr.responsetype = "json";         xhr.send();     });      let data = resp.target.response;      // use the response to construct form data object for the     // second request.
...And 2 more matches
   
 
   
    HTML to DOM - Archive of obsolete content
    
 although you can now natively parse html using domparser and 
xmlhttprequest, this is a new feature that is not yet supported by all browsers in use in the wild.
... safely parsing simple html to dom   when using 
xmlhttprequest to get the html of a remote webpage, it is often advantageous to turn that html string into dom for easier manipulation.
... parsing complete html to dom  loading an html document seems much simpler if it's loaded using the 
xmlhttprequest object.
... for that matter, we're going to load our html document first:  var request = 
xmlhttprequest(); request.open("get", "http://example.org/file.html", false); request.send(null);   our next step is to create the document object that will represent the dom into which we'll insert our newly-retrieved html:  var doc = document.implementation.createhtmldocument("example"); doc.documentelement.innerhtml = request.responsetext;   after this any manipulation that we might want to do will be something as simple as the following:  doc.body.textcontent = "this is inside the body!";     using a hidden iframe element to parse html to a window's dom  sample code may need more work.
   
 
   
    Enabling the behavior - retrieving tinderbox status - Archive of obsolete content
    
 var g
xmlhttprequest;  function loadtinderboxstatus() {   g
xmlhttprequest = new 
xmlhttprequest();   g
xmlhttprequest.onload = updatetinderboxstatus;   g
xmlhttprequest.open("get", "http://tinderbox.mozilla.org/seamonkey/panel.html");   g
xmlhttprequest.send(null); }   
xmlhttprequest is an interface in mozilla for retrieving documents via http.
... 
xmlhttprequest is easy to use in the simple case we have here.
... 
xmlhttprequest will retrieve the document located at the given url and call the updatetinderboxstatus() function when it is done.
...  notice that we defined the instance of 
xmlhttprequest as a global variable.
   
 
   
    WAI-ARIA basics - Learn web development
    
via 
xmlhttprequest, or dom apis.
...content that updates without the entire page reloading via a mechanism like 
xmlhttprequest, fetch, or dom apis.
...in this example we have a simple random quote box:  <section>   <h1>random quote</h1>   <blockquote>     <p></p>   </blockquote> </section>  our javascript loads a json file via 
xmlhttprequest containing a series of random quotes and their authors.
...  note: most browsers will throw a security exception if you try to do an 
xmlhttprequest call from a file:// url, e.g.
   
 
   
  
   
    Introduction to web APIs - Learn web development
    
apis that make this possible include 
xmlhttprequest and the fetch api.
... to provide another example, instances of the 
xmlhttprequest object (each one represents an http request to the server to retrieve a new resource of some kind) has a number of events available on them, for example, the load event is fired when a response has been successfully returned containing the requested resource, and it is now available.
...  the following code provides a simple example of how this would be used:  let requesturl = 'https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json'; let request = new 
xmlhttprequest(); request.open('get', requesturl); request.responsetype = 'json'; request.send();  request.onload = function() {   const superheroes = request.response;   populateheader(superheroes);   showheroes(superheroes); }   note: you can see this code in action in our ajax.html example (see it live also).
...   the first five lines specify the location of the resource we want to fetch, create a new instance of a request object using the 
xmlhttprequest() constructor, open an http get request to retrieve the specified resource, specify that the response should be sent in json format, then send the request.
   
 
   
    Handling common JavaScript problems - Learn web development
    
this is supposed to be fetched from an external .json file using the following 
xmlhttprequest call:  let requesturl = 'https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json'; let request = new 
xmlhttprequest(); request.open('get', requesturl); request.send();  let superheroes = request.response; populateheader(superheroes); showheroes(superheroes);  but this fails.
...this settles it — our 
xmlhttprequest call is returning the json as text, not json.
...to give you a clue, you can either tell the 
xmlhttprequest object explicitly to return json format, or convert the returned text to json after the response arrives.
...as an example, the fetch api (a modern equivalent to 
xmlhttprequest) uses promises to fetch resources across the network and make sure that the response has been returned before they are used (for example, displaying an image inside an <img> element).
   
 
   
    Index
    
       512     nsidomprogressevent     interfaces, interfaces:scriptable, reference, 
xmlhttprequest, xpcom interface reference, nsidomprogressevent, progress       the nsidomprogressevent is used in the media elements (<video> and <audio>) to inform interested code of the progress of the media download.
...       1099     nsi
xmlhttprequest     guide, interfaces, 
xmlhttprequest, xpcom api reference, xpcom interface reference       nsi
xmlhttprequest along with nsijs
xmlhttprequest and nsi
xmlhttprequesteventtarget are mozilla's implementation details of the dom 
xmlhttprequest object.
...        1100     nsi
xmlhttprequesteventtarget     interfaces, interfaces:scriptable, 
xmlhttprequest, xpcom, xpcom interface reference       when the handler functions for these events are called, they receive as a parameter a progressevent, which implements the nsidomprogressevent interface.
...        1101     nsi
xmlhttprequestupload     ajax, interfaces, interfaces:scriptable, 
xmlhttprequest, xpcom, xpcom interface reference       no summary!
   
 
   
    nsIUpdateCheckListener
    
        1.0    66        introduced gecko 1.8     inherits from: nsisupports last changed in gecko 1.8 (firefox 1.5 / thunderbird 1.5 / seamonkey 1.0)  method overview    void oncheckcomplete(in nsi
xmlhttprequest request, [array, size_is(updatecount)] in nsiupdate updates, in unsigned long updatecount);   void onerror(in nsi
xmlhttprequest request, in nsiupdate update);   void onprogress(in nsi
xmlhttprequest request, in unsigned long position, in unsigned long totalsize);    methods oncheckcomplete() called when the update check is completed.
... void oncheckcomplete(   in nsi
xmlhttprequest request,   [array, size_is(updatecount)] in nsiupdate updates,   in unsigned long updatecount );  parameters  request the nsi
xmlhttprequest object handling the update check.
...void onerror(   in nsi
xmlhttprequest request,   in nsiupdate update );  parameters  request the nsi
xmlhttprequest object handling the update check.
...void onprogress(   in nsi
xmlhttprequest request,   in unsigned long position,   in unsigned long totalsize );  parameters  request the nsi
xmlhttprequest object handling the update check.
   
 
   
    Beacon API - Web APIs
    
requests are guaranteed to be initiated before a page is unloaded and they are run to completion, without requiring a blocking request (for example 
xmlhttprequest).
... user agents will typically ignore asynchronous 
xmlhttprequests made in an unload handler.
... to solve this problem, analytics and diagnostics code will typically make a synchronous 
xmlhttprequest in an unload or beforeunload handler to submit the data.
... the synchronous 
xmlhttprequest forces the browser to delay unloading the document, and makes the next navigation appear to be slower.
   
 
   
    Navigator.sendBeacon() - Web APIs
    
 ensuring that data has been sent during the unloading of a document has traditionally been difficult, because user agents typically ignore asynchronous 
xmlhttprequests made in an unload handler.
...  historically, this was addressed with some of the following workarounds to delay the page unload long enough to send data to some url:    submitting the data with a blocking synchronous 
xmlhttprequest call in unload or beforeunload event handlers.
... the following example shows theoretical analytics code that attempts to submit data to a server with a synchronous 
xmlhttprequest in an unload handler.
... window.addeventlistener("unload", function logdata() {   var xhr = new 
xmlhttprequest();   xhr.open("post", "/log", false); // third parameter of `false` means synchronous   xhr.send(analyticsdata); });   this is what sendbeacon() replaces.
   
 
   
    msCachingEnabled - Web APIs
    
        the mscachingenabled method gets the current caching state for an 
xmlhttprequest.
... syntax   var cachestate = 
xmlhttprequest.mscachingenabled();   parameters    cachestate[out, retval]  type = boolean.
... if true, 
xmlhttprequest is cached to disk.
...if true, 
xmlhttprequest is cached to disk.
   
 
   
    Loading and running WebAssembly code - WebAssembly
    
  using 
xmlhttprequest  xmlhttprequest is somewhat older than fetch, but can still be happily used to get a typed array.
... again, assuming our module is called simple.wasm:    create a new 
xmlhttprequest() instance, and use its open() method to open a request, setting the request method to get, and declaring the path to the file we want to fetch.
... next, send the request using 
xmlhttprequest.send().
...  the final code looks like this:  request = new 
xmlhttprequest(); request.open('get', 'simple.wasm'); request.responsetype = 'arraybuffer'; request.send();  request.onload = function() {   var bytes = request.response;   webassembly.instantiate(bytes, importobject).then(results => {     results.instance.exports.exported_func();   }); };   note: you can see an example of this in action in xhr-wasm.html.
   
 
   
    Cross-domain Content Scripts - Archive of obsolete content
    
in particular, they can't:    access content hosted in an iframe, if that content is served from a different domain  make cross-domain 
xmlhttprequests   however, you can enable these features for specific domains by adding them to your add-on's package.json under the "cross-domain-content" key, which itself lives under the "permissions" key:  "permissions": {     "cross-domain-content": ["http://example.org/", "http://example.com/"] }     the domains listed must include the scheme and fully qualified domain name, and these must exactly match the domains serving the content - so in the example above, the content script will not be allowed to access content served from https://example.com/.
... cross-domain 
xmlhttprequest  the following add-on creates a panel whose content is the summary weather forecast for shetland.
...quire("sdk/ui/button/action").actionbutton({   id: "get-forecast",   label: "get the forecast",   icon: "./icon-16.png",   onclick: function() {     forecast_panel.show();   } });   the "panel.html" just includes a <div> block for the forecast:  <!doctype html> <!-- panel.html -->  <html>   <head></head>   <body>     <div id="forecast_summary"></div>   </body> </html>   the "panel-script.js" uses 
xmlhttprequest to fetch the latest forecast:  // panel-script.js  var url = "http://datapoint.metoffice.gov.uk/public/data/txt/wxfcs/regionalforecast/json/500?key=your-api-key";  self.port.on("show", function () {   var request = new 
xmlhttprequest();   request.open("get", url, true);   request.onload = function () {     var jsonresponse = json.parse(request.responsetext);     var summary = getsummary(jsonrespo...
   
 
   
    Creating a dynamic status bar extension - Archive of obsolete content
    
   httprequest = new 
xmlhttprequest();    httprequest.open('get', fullurl, true);   httprequest.onload = inforeceived;   httprequest.send(null); }  the httprequest variable will contain an 
xmlhttprequest object.
...the first thing we do is create a new 
xmlhttprequest object to use for processing our request.
...we then fetch the result returned by the web server into the variable output from the 
xmlhttprequest.responsetext property.
   
 
   
    JXON - Archive of obsolete content
    
if you have already have a dom tree from using 
xmlhttprequest, skip to the next paragraph.
...  note: if you are using an instance of 
xmlhttprequest in order to retrieve your xml file, please use the yourrequest.responsexml property to get a parsed xml document.
...    alert((new xmlserializer()).serializetostring(newdoc));  };  var oreq = new 
xmlhttprequest(); oreq.onload = reqlistener; oreq.open("get", "example.xml", true); oreq.send();  jxon.build syntax  jxon.build(document[, verbosity[, freeze[, nesteattributes]]])  jxon.build description  returns a javascript object based on the given xml document.
   
 
   
    jspage - Archive of obsolete content
    
on!=undefined)?"ipod":(navigator.platform.match(/mac|win|linux/i)||["other"])[0].tolowercase()},features:{xpath:!!(document.evaluate),air:!!(window.runtime),query:!!(document.queryselector)},plugins:{},engines:{presto:function(){return(!window.opera)?false:((arguments.callee.caller)?960:((document.getelementsbyclassname)?950:925)); },trident:function(){return(!window.activexobject)?false:((window.
xmlhttprequest)?((document.queryselectorall)?6:5):4);},webkit:function(){return(navigator.taintenabled)?false:((browser.features.xpath)?((browser.features.query)?525:420):419); },gecko:function(){return(!document.getboxobjectfor&&window.mozinnerscreenx==null)?false:((document.getelementsbyclassname)?19:18);}}},browser||{});browser.platform[browser.platform.name]=true; browser.detect=function(){for(var b in this...
....engines){var a=this.engines[b]();if(a){this.engine={name:b,version:a};this.engine[b]=this.engine[b+a]=true; break;}}return{name:b,version:a};};browser.detect();browser.request=function(){return $try(function(){return new 
xmlhttprequest();},function(){return new activexobject("msxml2.xmlhttp"); },function(){return new activexobject("microsoft.xmlhttp");});};browser.features.xhr=!!(browser.request());browser.plugins.flash=(function(){var a=($try(function(){return navigator.plugins["shockwave flash"].description; },function(){return new activexobject("shockwaveflash.shockwaveflash").getvariable("$version");})||"0 r0").match(/\d+/g);return{version:parseint(a[0]||0+"."+a[1],10)||0,build:parseint(a[2],10)||0}; })();function $exec(b){if(!b){return b;}if(window.execscript){window.execscript(b);}else{var a=docu...
...f(f>=(7-4*d)/11){e=c*c-math.pow((11-6*d-11*f)/4,2); break;}}return e;},elastic:function(b,a){return math.pow(2,10*--b)*math.cos(20*b*math.pi*(a[0]||1)/3);}});["quad","cubic","quart","quint"].each(function(b,a){fx.transitions[b]=new fx.transition(function(c){return math.pow(c,[a+2]); });});var request=new class({implements:[chain,events,options],options:{url:"",data:"",headers:{"x-requested-with":"
xmlhttprequest",accept:"text/javascript, text/html, application/xml, text/xml, */*"},async:true,format:false,method:"post",link:"ignore",issuccess:null,emulation:true,urlencoded:true,encoding:"utf-8",evalscripts:false,evalresponse:false,nocache:false},initialize:function(a){this.xhr=new browser.request(); this.setoptions(a);this.options.issuccess=this.options.issuccess||this.issuccess;this.headers=new hash(this...
   
 
   
    Uploading and Downloading Files - Archive of obsolete content
    
this operation can also be performed via a script using the 
xmlhttprequest object.
...the formdata object can then simply be passed to 
xmlhttprequest:  function upload(posturl, fieldname, filepath) {   var formdata = new formdata();   formdata.append(fieldname, new file(filepath));    var req = new 
xmlhttprequest();   req.open("post", posturl);   req.onload = function(event) { alert(event.target.responsetext); };   req.send(formdata); }   http put  you can also upload a file using an http put operation.
... function uploadput(posturl, filepath) {   var req = new 
xmlhttprequest();   req.open("put", posturl);   req.setrequestheader("content-type", "text/plain");   req.onload = function(event) { alert(event.target.responsetext); }   req.send(new file(filepath)); }   in this example, a new input stream is created for a file, and is passed to the 
xmlhttprequest's send method.
   
 
   
    Index - MDN Web Docs Glossary: Definitions of Web-related terms
    
       14     ajax     ajax, codingscripting, glossary, infrastructure, l10n:priority       ajax, which initially stood for asynchronous javascript and xml, is a programming practice of building complex, dynamic webpages using a technology known as 
xmlhttprequest.
...       391     spa (single-page application)     glossary, spa, single-page app       an spa (single-page application) is a web app implemention that loads only a single web document, and then updates the body content of that single document via javascript apis such as 
xmlhttprequest and fetch when different content is to be shown.
...       507     xhr (
xmlhttprequest)     api, beginner, codingscripting, glossary, 
xmlhttprequest       xmlhttprequest (xhr) is a javascript api to create ajax requests.
   
 
   
    Introducing asynchronous JavaScript - Learn web development
    
let's look at another example that loads a resource via the 
xmlhttprequest api (run it live, and see the source):  function loadasset(url, type, callback) {   let xhr = new 
xmlhttprequest();   xhr.open('get', url);   xhr.responsetype = type;    xhr.onload = function() {     callback(xhr.response);   };    xhr.send(); }  function displayimage(blob) {   let objecturl = url.createobjecturl(blob);    let image = document.createelement('img');   image.src = objecturl;   docu...
...it uses 
xmlhttprequest (often abbreviated to "xhr") to fetch the resource at the given url, then pass the response to the callback to do something with.
...a good example is the fetch() api, which is basically like a modern, more efficient version of 
xmlhttprequest.
   
 
   
  
   
    Working with JSON - Learn web development
    
 we are going to load it into our page, and use some nifty dom manipulation to display it, like this:    obtaining the json  to obtain the json, we use an api called 
xmlhttprequest (often called xhr).
...add the following at the bottom of your javascript code:   let requesturl = 'https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json';    to create a request, we need to create a new request object instance from the 
xmlhttprequest constructor, using the new keyword.
... add the following below your last line:   let request = new 
xmlhttprequest();    now we need to open the request using the open() method.
   
 
   
    Components.utils.importGlobalProperties
    
 system scopes such as jsms and frame scripts don't have certain objects, such as indexeddb and 
xmlhttprequest, that are available to dom window globals.
...nt              atob               blob                btoa               crypto                css                fetch                file     nsidomfile          indexeddb               nodefilter firefox 60    nsidomnodefilter obsolete since gecko 60          rtcidentityprovider                textdecoder               textencoder               url               urlsearchparams                
xmlhttprequest    nsi
xmlhttprequest obsolete since gecko 60         for string/object in table without a minimum firefox version, it is not exactly known since when it was available, however it is guranteed available from firefox 28 and up.
... var domfile = services.appshell.hiddendomwindow.file('/path/to/file');  xpcom components  some objects have an xpcom alternative, which typically allows more flexibility then the dom version  here is an example of how to use the dom 
xmlhttprequest through xpcom interface of nsi
xmlhttprequest:  var oreq = cc["@mozilla.org/xmlextras/
xmlhttprequest;1"].createinstance(ci.nsi
xmlhttprequest);                                ...
   
 
   
    nsIIOService
    
but if the load is coming from a js api (such as 
xmlhttprequest) or if the load might be coalesced across multiple elements (such as for ) then pass in the document node instead.
...but if the load is coming from a js api (such as 
xmlhttprequest) or if the load might be coalesced across multiple elements (such as for <img>) then pass in the document node instead.
...but if the load is coming from a js api (such as 
xmlhttprequest) or if the load might be coalesced across multiple elements (such as for ) then pass in the document node instead.
   
 
   
    BaseAudioContext.decodeAudioData() - Web APIs
    
in this case the arraybuffer is loaded from 
xmlhttprequest and filereader.
... syntax  older callback syntax:  baseaudiocontext.decodeaudiodata(arraybuffer, successcallback, errorcallback);  newer promise-based syntax:  promise<decodeddata> baseaudiocontext.decodeaudiodata(arraybuffer);  parameters    arraybuffer  an arraybuffer containing the audio data to be decoded, usually grabbed from 
xmlhttprequest, windoworworkerglobalscope.fetch() or filereader.
...// then we put the buffer into the source  function getdata() {   source = audioctx.createbuffersource();   var request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';     request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {         source.buffer = buffer;          source.connect(audioctx.destination);         source.loop = true;       },        function(e){ console.log("error with decoding audio data"...
   
 
   
    ProgressEvent - Web APIs
    
 the progressevent interface represents events measuring progress of an underlying process, like an http request (for an 
xmlhttprequest, or the loading of the underlying resource of an <img>, <audio>, <video>, <style> or <link>).
...  examples  the following example adds a progressevent to a new 
xmlhttprequest and uses it to display the status of the request.
...  var progressbar = document.getelementbyid("p"),     client = new 
xmlhttprequest() client.open("get", "magical-unicorns") client.onprogress = function(pe) {   if(pe.lengthcomputable) {     progressbar.max = pe.total     progressbar.value = pe.loaded   } } client.onloadend = function(pe) {   progressbar.value = pe.loaded } client.send()  specifications           specification    status    comment          
xmlhttprequestthe definition of 'progressevent' in that specification.
   
 
   
    Functions and classes available to Web Workers - Web APIs
    
   8 (8)    no support    no support    no support          formdata    formdata objects provide a way to easily construct a set of key/value pairs representing form fields and their values, which can then be easily sent using the 
xmlhttprequest send() method.
...   basic implementation (yes)     appcodename, product, taintenabled(): 28 (28)     online: 29 (29)     navigatorlanguage: (yes)    appname, appversion, online, platform, useragent: 10.0     other: no support    (yes)    (yes)          
xmlhttprequest    creates and returns a new 
xmlhttprequest  object; this mimics the behavior of the standard 
xmlhttprequest() constructor.
... note that the responsexml and channel attributes on 
xmlhttprequest always return null.
   
 
   
    Using Web Workers - Web APIs
    
in addition, they can perform i/o using 
xmlhttprequest (although the responsexml and channel attributes are always null).
...in addition, workers may use 
xmlhttprequest for network i/o, with the exception that the responsexml and channel attributes on 
xmlhttprequest always return null.
...  functions and interfaces available in workers  you can use most standard javascript features inside a web worker, including:    navigator  
xmlhttprequest  array, date, math, and string  windowtimers.settimeout and windowtimers.setinterval   the main thing you can't do in a worker is directly affect the parent page.
   
 
   
    Index - Developer guides
    
       2     ajax     ajax, dom, json, javascript, references, 
xmlhttprequest       asynchronous javascript and xml, while not a technology in itself, is a term coined in 2005 by jesse james garrett, that describes a "new" approach to using a number of existing technologies together        3     community     ajax       if you know of useful mailing lists, newsgroups, forums, or other communities related to ajax, please link to them here.
...        4     getting started     ajax, api, advanced, javascript, webmechanics, 
xmlhttprequest       this article guides you through the ajax basics and gives you some simple hands-on examples to get you started.
...       37     parsing and serializing xml     ajax, add-ons, dom, dom parsing, document, extensions, guide, htmldocument, json, parsing, parsing xml, serializing, serializing xml, xml, xmldocument, 
xmlhttprequest       in this article, we'll look at the objects provided by the web platform to make the common tasks of serializing and parsing xml easy.
   
 
   
    Parsing and serializing XML - Developer guides
    
 xmlhttprequest  loads content from a url; xml content is returned as an xml document object with a dom tree built from the xml itself.
..."error while parsing" : odom.documentelement.nodename);    parsing url-addressable resources into dom trees  using 
xmlhttprequest  here is sample code that reads and parses a url-addressable xml file into a dom tree:  var xhr = new 
xmlhttprequest(); xhr.onload = function() {   dump(xhr.responsexml.documentelement.nodename); } xhr.onerror = function() {   dump("error while getting xml."); } xhr.open("get", "example.xml"); xhr.responsetype = "document"; xhr.send();   the value returned in the xhr object's responsexml field is...
...alternatively, use a dom tree obtained from 
xmlhttprequest.
   
 
   
    request - Archive of obsolete content
    
for more advanced usage, check out the net/xhr module, based on the browser's 
xmlhttprequest object.
...this option sets the mozanon property in the underlying 
xmlhttprequest object.
   
 
   
    Twitter - Archive of obsolete content
    
in fact it's hardly more than syntactic sugar for doing 
xmlhttprequests.
...  error(
xmlhttprequest, textstatus, errorthrown)  
xmlhttprequest is the xhr used in the request.
   
 
   
    Supporting per-window private browsing - Archive of obsolete content
    
var channel = services.io.newchannel("http://example.org", null, null); channel.queryinterface(components.interfaces.nsiprivatebrowsingchannel); channel.setprivate(true); // force the channel to be loaded in private mode similarly, 
xmlhttprequest objects created via createinstance(ci.nsi
xmlhttprequest) will often require explicit adjustment, since they have no context from which to derive a privacy status.
... var xhr = components.classes["@mozilla.org/xmlextras/
xmlhttprequest;1"].createinstance(components.interfaces.nsixmlhttpreqeust); var channel = xhr.channel.queryinterface(components.interfaces.nsiprivatebrowsingchannel); channel.setprivate(true);                                ...
   
 
   
    XInclude - MDN Web Docs Glossary: Definitions of Web-related terms
    
 }             var j;             var xincludeparent = xinclude.parentnode;             try {                 netscape.security.privilegemanager.enableprivilege('universalxpconnect universalbrowserread'); // necessary with file:///-located files trying to reach external sites                 if (href !== null) {                     var response, responsetype;                     var request = new 
xmlhttprequest();                     request.open('get', href, false);                     request.setrequestheader('if-modified-since', 'thu, 1 jan 1970 00:00:00 gmt');                     request.setrequestheader('cache-control', 'no-cache');                     if (accept) {                         request.setrequestheader('accept', accept);                     }                     if (acceptlanguage) {   ...
...e[2];                                   }                                   else {                                       encodingtype = 'utf-8';                                   }                                   // need to make a whole new request apparently since cannot convert the encoding after receiving it (to know what the encoding was)                                   var request2 = new 
xmlhttprequest();                                   request2.overridemimetype('text/plain; charset='+encodingtype);                                   request2.open('get', href, false);                                   request2.setrequestheader('if-modified-since', 'thu, 1 jan 1970 00:00:00 gmt');                                   request2.setrequestheader('cache-control', 'no-cache');                          ...
   
 
   
    Index - Learn web development
    
       59     fetching data from the server     api, article, beginner, codingscripting, fetch, json, javascript, learn, promises, server, xhr, xml, 
xmlhttprequest, data, request       this article shows how to start working with both xhr and fetch to fetch data from the server.
...but forms can also prepare an http request to send via javascript, for example via 
xmlhttprequest.
   
 
   
    Feed content access API
    
use an 
xmlhttprequest to load the feed, then pass its string to an nsifeedprocessor to parse the feed.
...ses["@mozilla.org/feed-processor;1"]                                         .createinstance(components.interfaces.nsifeedprocessor);         var listener = new feedtestresultlistener();         try {           parser.listener = listener;           parser.parsefromstring(data, uri);         }         catch(e) {           alert("error parsing feed.");         }       }     }      httprequest = new 
xmlhttprequest();      httprequest.open("get", feedurl, true);     try {       httprequest.onload = inforeceived;       httprequest.send(null);     }     catch(e) {       alert(e);     }   }  the nsifeedprocessor interface lets you parse the feed data from several possible sources; in this case, we're loading a document into a string, then parsing that string using its parsefromstring() method.
   
 
   
  
   
    nsIDOMProgressEvent
    
         dom/interfaces/events/nsidomprogressevent.idlscriptable   this interface represents the events sent with progress information while uploading data using the 
xmlhttprequest object.
...  see also    using 
xmlhttprequest  xmlhttprequest  nsi
xmlhttprequesteventtarget  nsi
xmlhttprequest                                 ...
   
 
   
    XPCOM Interface Reference by grouping
    
 nsidownloadprogresslistener      element   internal        nsiworker     nsiworkerglobalscope     nsiworkermessageevent     nsiworkermessageport     nsiworkerscope      tree        nsitreeboxobject     nsitreecolumn     nsitreecolumns     nsitreecontentview     nsitreeselection     nsitreeview      xform        nsixformsmodelelement     nsixformsnsinstanceelement     nsixformsnsmodelelement      
xmlhttprequest        nsi
xmlhttprequesteventtarget      favicon        nsifavicondatacallback     nsifaviconservice      frame        nsichromeframemessagemanager     nsiframeloader     nsiframeloaderowner     nsiframemessagelistener     nsiframemessagemanager      interface        nsijs
xmlhttprequest      jetpack        nsijetpack     nsijetpackservice      offlinestorage        nsiapplicationcache     nsiappl...
...rint32     nsisupportsprint64     nsisupportspriority     nsisupportsprtime     nsisupportspruint16     nsisupportspruint32     nsisupportspruint64     nsisupportspruint8     nsisupportsstring     nsisupportsvoid     nsisupportsweakreference     nsivariant      do not use        nsienumerator     nsiinprocesscontentframemessagemanager     nsiscriptableio     nsixpcscriptable      future        nsi
xmlhttprequestupload      obsolete        nsixmlrpcclient     nsixmlrpcfault      security               auth                nsiauthmodule         nsiauthprompt         nsiauthpromptprovider         nsiauthpromptwrapper         nsiasyncverifyredirectcallback              content                nsicontentpolicy              credentials                nsilogininfo         nsiloginmanager         using nsiloginman...
   
 
   
    Index - Firefox Developer Tools
    
       46     network monitor     debugging, dev tools, firefox, guide, networking, tools, l10n:priority       the network monitor shows you all the network requests firefox makes (for example, when it loads a page, or due to 
xmlhttprequests), how long each request takes, and details of each request.
...       135     set an xhr breakpoint     debugger, debugging, javascript, xhr breakpoint       an xhr (
xmlhttprequest) breakpoint breaks code execution when an xhr request is dispatched so that you can examine the current state of the program.
   
 
   
    Using Fetch - Web APIs
    
  this kind of functionality was previously achieved using 
xmlhttprequest.
...for example:  if (window.fetch) {   // run my fetch request here } else {   // do something with 
xmlhttprequest?
   
 
   
    FormData - Web APIs
    
 the formdata interface provides a way to easily construct a set of key/value pairs representing form fields and their values, which can then be easily sent using the 
xmlhttprequest.send() method.
...  specifications           specification    status    comment          
xmlhttprequestthe definition of 'formdata' in that specification.
   
 
   
    FormDataEvent - Web APIs
    
 this allows a formdata object to be quickly obtained in response to a formdata event firing, rather than needing to put it together yourself when you wish to submit form data via a method like 
xmlhttprequest (see using formdata objects).
...  // construct a formdata object, which fires the formdata event   new formdata(formelem); });  // formdata handler to retrieve data  formelem.addeventlistener('formdata', (e) => {   console.log('formdata fired');    // get the form data from the event object   let data = e.formdata;   for (var value of data.values()) {     console.log(value);   }    // submit the data via xhr   var request = new 
xmlhttprequest();   request.open("post", "/formhandler");   request.send(data); });  specifications           specification    status    comment          html living standardthe definition of 'formdataevent' in that specification.
   
 
   
    Working with the History API - Web APIs
    
 adding and modifying history entries    using pushstate() changes the referrer that gets used in the http header for 
xmlhttprequest objects created after you change the state.
... the referrer will be the url of the document whose window is this at the time of creation of the 
xmlhttprequest object.
   
 
   
    MediaSource - Web APIs
    
  examples  the following simple example loads a video with 
xmlhttprequest, playing it as soon as it can.
...ource = this;   var sourcebuffer = mediasource.addsourcebuffer(mimecodec);   fetchab(asseturl, function (buf) {     sourcebuffer.addeventlistener('updateend', function (_) {       mediasource.endofstream();       video.play();       //console.log(mediasource.readystate); // ended     });     sourcebuffer.appendbuffer(buf);   }); };  function fetchab (url, cb) {   console.log(url);   var xhr = new 
xmlhttprequest;   xhr.open('get', url);   xhr.responsetype = 'arraybuffer';   xhr.onload = function () {     cb(xhr.response);   };   xhr.send(); };  specifications           specification    status    comment          media source extensionsthe definition of 'mediasource' in that specification.
   
 
   
    Resource Timing API - Web APIs
    
an application can use the timing metrics to determine, for example, the length of time it takes to load a specific resource, such as an 
xmlhttprequest, <svg>, image, or script.
... the initiatortype property returns the type of resource that initiated the performance entry such as "css" for a css resource, "
xmlhttprequest" for an 
xmlhttprequest and "img" for an image (such as a jpeg).
   
 
   
    Using Service Workers - Web APIs
    
(see our promises test example for the source code, or look at it running live.)  note: a real service worker implementation would use caching and onfetch rather than the 
xmlhttprequest api.
... const imgload = (url) => {   return new promise((resolve, reject) => {     var request = new 
xmlhttprequest();     request.open('get', url);     request.responsetype = 'blob';      request.onload = () => {       if (request.status == 200) {         resolve(request.response);       } else {         reject(error('image didn\'t load successfully; error code:' + request.statustext));       }     };      request.onerror = () => {       reject(error('there was a network error.'));     };      request.send();   }); }  we return a new promise using the promise() constructor, which takes as an argument a callback function with resolve and reject parameters.
   
 
   
    Migrating from webkitAudioContext - Web APIs
    
 the example below shows old code which downloads an audio file over the network, and then decoded it using createbuffer():  var xhr = new 
xmlhttprequest(); xhr.open("get", "/path/to/audio.ogg", true); xhr.responsetype = "arraybuffer"; xhr.send(); xhr.onload = function() {   var decodedbuffer = context.createbuffer(xhr.response, false);   if (decodedbuffer) {     // decoding was successful, do something useful with the audio buffer   } else {     alert("decoding the audio buffer failed");   } };   converting this code to use decodeaudiodata() is r...
...elatively simple, as can be seen below:  var xhr = new 
xmlhttprequest(); xhr.open("get", "/path/to/audio.ogg", true); xhr.responsetype = "arraybuffer"; xhr.send(); xhr.onload = function() {   context.decodeaudiodata(xhr.response, function onsuccess(decodedbuffer) {     // decoding was successful, do something useful with the audio buffer   }, function onfailure() {     alert("decoding the audio buffer failed");   }); };  note that the decodeaudiodata() method is asynchronous, which means that it will return immediately, and then when the decoding finishes, one of the success or failure callback functions will get called depending on whether the audio decoding was successful.
   
 
   
    Web Authentication API - Web APIs
    
typically, server communications would be rest over https (probably using 
xmlhttprequest or fetch), but they could also be soap, rfc 2549 or nearly any other protocol provided that the protocol is secure.
...typically, server communications would be rest over https (probably using 
xmlhttprequest or fetch), but they could also be soap, rfc 2549 or nearly any other protocol provided that the protocol is secure.
   
 
   
    DOM onevent handlers - Developer guides
    
 non-element objects  event handlers can also be set with properties on non-element objects that generate events, like window, document, 
xmlhttprequest, and others.
... for example, for the progress event on instances of 
xmlhttprequest:  const xhr = new 
xmlhttprequest(); xhr.onprogress = function() { … };  html onevent attributes  html elements have attributes named onevent which can be used to register a handler for an event directly within the html code.
   
 
   
    Access-Control-Allow-Credentials - HTTP
    
 the access-control-allow-credentials header works in conjunction with the 
xmlhttprequest.withcredentials property or with the credentials option in the request() constructor of the fetch api.
...  examples  allow credentials:  access-control-allow-credentials: true  using xhr with credentials:  var xhr = new 
xmlhttprequest(); xhr.open('get', 'http://example.com/', true); xhr.withcredentials = true; xhr.send(null);  using fetch with credentials:  fetch(url, {   credentials: 'include' })  specifications           specification    status    comment              fetchthe definition of 'access-control-allow-credentials' in that specification.
   
 
   
    CSP: connect-src - HTTP
    
the apis that are restricted are:    <a> ping,  fetch,  
xmlhttprequest,  websocket,  eventsource, and  navigator.sendbeacon().
...  examples  violation cases  given this csp header:  content-security-policy: connect-src https://example.com/  the following connections are blocked and won't load:  <a ping="https://not-example.com">  <script>   var xhr = new 
xmlhttprequest();   xhr.open('get', 'https://not-example.com/');   xhr.send();    var ws = new websocket("https://not-example.com/");    var es = new eventsource("https://not-example.com/");    navigator.sendbeacon("https://not-example.com/", { ...
   
 
   
  
   
    HTTP Index - HTTP
    
       20     cross-origin resource sharing (cors)     ajax, cors, cross-origin resource sharing, fetch, fetch api, http, http access controls, same-origin policy, security, 
xmlhttprequest, l10n:priority       cross-origin resource sharing (cors) is a mechanism that uses additional http headers to tell browsers to give a web application running at one origin, access to selected resources from a different origin.
...       144     feature-policy: sync-xhr     directive, feature policy, feature-policy, http, reference, 
xmlhttprequest       the http feature-policy header sync-xhr directive controls whether the current document is allowed to make synchronous 
xmlhttprequest requests.
   
 
   
    Introduction to using XPath in JavaScript - XPath
    
 /> 	<address street="1600 pennsylvania avenue" city="washington" country="usa"/> 	<phonenumber>202-456-1111</phonenumber>   </person>   <person> 	<name first="tony" last="blair" /> 	<address street="10 downing street" city="london" country="uk"/> 	<phonenumber>020 7925 0918</phonenumber>   </person> </people>   to make the contents of the xml document available within the extension, we create an 
xmlhttprequest object to load the document synchronously, the variable xmldoc will contain the document as an xmldocument object against which we can use the evaluate method  javascript used in the extensions xul/js documents.
...  var req = new 
xmlhttprequest();  req.open("get", "chrome://yourextension/content/peopledb.xml", false); req.send(null);  var xmldoc = req.responsexml;		  var nsresolver = xmldoc.creatensresolver( xmldoc.ownerdocument == null ?
   
 
   
    Basic Example - XSLT: Extensible Stylesheet Language Transformations
    
f select="@company" />  </b>     </xsl:if>      <br />   </xsl:template>    <xsl:template match="myns:body">     <xsl:copy>       <xsl:apply-templates select="@*|node()"/>     </xsl:copy>   </xsl:template>    <xsl:template match="@*|node()">       <xsl:copy>         <xsl:apply-templates select="@*|node()"/>       </xsl:copy>   </xsl:template> </xsl:stylesheet>  the example loads using synchronous 
xmlhttprequest both the .xsl (xslstylesheet) and the .xml (xmldoc) files into memory.
... figure 6 : example  var xslstylesheet; var xsltprocessor = new xsltprocessor(); var mydom;  var xmldoc;  function init(){    // load the xslt file, example1.xsl   var my
xmlhttprequest = new 
xmlhttprequest();   my
xmlhttprequest.open("get", "example1.xsl", false);   my
xmlhttprequest.send(null);    xslstylesheet = my
xmlhttprequest.responsexml;   xsltprocessor.importstylesheet(xslstylesheet);     // load the xml file, example1.xml   my
xmlhttprequest = new 
xmlhttprequest();   my
xmlhttprequest.open("get", "example1.xml", false);   my
xmlhttprequest.send(null);    xmldoc = myxmlhttpre...
   
 
   
    JavaScript/XSLT Bindings - XSLT: Extensible Stylesheet Language Transformations
    
this can be done via 
xmlhttprequest or xmldocument.load().
...  figure 1 : instantiating an xsltprocessor    var xsltprocessor = new xsltprocessor();    // load the xsl file using synchronous (third param is set to false) 
xmlhttprequest   var my
xmlhttprequest = new 
xmlhttprequest();   my
xmlhttprequest.open("get", "example.xsl", false);   my
xmlhttprequest.send(null);    var xslref = my
xmlhttprequest.responsexml;    // finally import the .xsl   xsltprocessor.importstylesheet(xslref);   for the actual transformation, xsltprocessor requires an xml document, which is used in conjunction with the imported xsl file to produce the final result.
   
 
   
   
    core/promise - Archive of obsolete content
    
lets see the implementation of readasync that we used in several of the examples above:  const { defer } = require('sdk/core/promise'); function readasync(url) {   var deferred = defer();    let xhr = new 
xmlhttprequest();   xhr.open("get", url, true);   xhr.onload = function() {     deferred.resolve(xhr.responsetext);   };   xhr.onerror = function(event) {     deferred.reject(event);   };   xhr.send();    return deferred.promise; }  so defer returns an object that contains a promise and two resolve, reject functions that can be used to resolve / reject that promise.
   
 
   
   
   
    File I/O - Archive of obsolete content
    
var file = url.queryinterface(components.interfaces.nsifileurl).file; // file is a nsifile   to load from file://, http://, chrome://, resource:// and other urls directly, use 
xmlhttprequest or netutil.asyncfetch().
   
 
   
   
    Rosetta - Archive of obsolete content
    
"" : odicts[smimetype](oscript.text);     obaton.parentnode.insertbefore(ocompiled, obaton);    }    function reqerror (oerror) {     throw new urierror("the script " + oerror.target.src + " is not accessible.");   }    function reqsuccess () {     createscript(this.refscript, this);   }    function getsource (oscript) {     var oreq = new 
xmlhttprequest();     oreq.onload = reqsuccess;     oreq.onerror = reqerror;     oreq.refscript = oscript;     oreq.open("get", oscript.src, true);     oreq.send(null);   }    function parsescript (oscript) {     if (oscript.hasattribute("type") && !rignoremimes.test(oscript.getattribute("type").tolowercase())) {       oscript.hasattribute("src") ?
   
 
   
    XML-related code snippets - Archive of obsolete content
    
   how to create a dom tree  using 
xmlhttprequest  parsing and serializing xml  using xpath  jxon (lossless javascript xml object notation)  xsl transforms  xlink  xinclude  xml:id  xml:base support in old browsers  xpointer  svg  namespaces, or why http://www.mozilla.org/keymaster/gat...re.is.only.xul is at the top of every xul document.
   
 
   
    Displaying web content in an extension without security issues - Archive of obsolete content
    
so in the simplest case you would have: <iframe type="content" src="data:text/html,%3chtml%3e%3cbody%3e%3c/body%3e%3c/html%3e"/>  but usually you don’t want to start with an empty document, you would rather want to load some template into the frame: var request = new 
xmlhttprequest(); request.open("get", "chrome://foo/content/template.html", false); request.send(null); frame.setattribute("src", "data:text/html," + encodeuricomponent(request.responsetext));  that way you can have the template in your extension but still strip it off all privileges when it is loaded in a frame.
   
 
   
   
    Jetpack Processes - Archive of obsolete content
    
these arbitrary properties are the primary means through which context can be provided for messages; for instance, if the handle is meant to represent a network request, an 
xmlhttprequest instance can be attached to the handle on the chrome process.
   
 
   
  
   
   
   
   
    Adding preferences to an extension - Archive of obsolete content
    
          var fieldarray = output.split(",");          samplepanel.label = symbol + ": " + fieldarray[1];          samplepanel.tooltiptext = "chg: " + fieldarray[4] + " | " +              "open: " + fieldarray[5] + " | " +              "low: " + fieldarray[6] + " | " +              "high: " + fieldarray[7] + " | " +              "vol: " + fieldarray[8];        }      }       var httprequest = new 
xmlhttprequest();       httprequest.open("get", fullurl, true);      httprequest.onload = inforeceived;      httprequest.send(null);    } }   note that we use stockwatcher.tickersymbol here instead of this.tickersymbol to get the stock symbol to watch.
   
 
   
   
    Enabling the behavior - updating the status bar panel - Archive of obsolete content
    
 function updatetinderboxstatus() {   var icon = document.getelementbyid('tinderbox-status');    if (g
xmlhttprequest.responsetext.match("ee0000"))     icon.setattribute("status", "busted");   else if (g
xmlhttprequest.responsetext.match("ffaa00"))     icon.setattribute("status", "testfailed");   else if (g
xmlhttprequest.responsetext.match("11dd11"))     icon.setattribute("status", "success");   else     icon.setattribute("status", ""); }   updatetinderboxstatus() retrieves a reference to the statusbarpanel element then searches through the retrieved html document (stored in the responsetext property of the 
xmlhttprequest instance) for one of several color references.
   
 
   
    Enabling the behavior - updating the status periodically - Archive of obsolete content
    
 function loadtinderboxstatus() {   g
xmlhttprequest = new 
xmlhttprequest();   g
xmlhttprequest.onload = updatetinderboxstatus;   g
xmlhttprequest.open("get", "http://tinderbox.mozilla.org/seamonkey/panel.html");   g
xmlhttprequest.send(null);   window.settimeout(loadtinderboxstatus, 60000); }  window.settimeout(loadtinderboxstatus, 1000);   window.settimeout schedules functions to run at some future time.
   
 
   
    Me - Archive of obsolete content
    
onfirstrun() may be called anywhere in your jetpack, but if it is called as the result of some asynchronous operation such as a timeout or 
xmlhttprequest, it is ignored.
   
 
   
   
   
    XML in Mozilla - Archive of obsolete content
    
outside supported xml w3c recommendations                specification or technology       documentation       mozilla project                 xslt       w3c recommendation       xslt                 xpath       w3c recommendation       xslt                 
xmlhttprequest       w3c recommendation       xml extras                 request api (no longer supported)       mozilla       add-on sdk                 domparser and xmlserializer       mozilla       xml extras                 sax       sax                         soap (no longer supported)       w3c note       web services                 xml-rpc (no longer supported)       userland software       xml-rpc   ...
   
 
   
    Using SOAP in XULRunner 1.9 - Archive of obsolete content
    
pe: soapclient.contenttype + "; charset=\"" + soapclient.charset + "\"", < 				 beforesend: function(req) { < 					req.setrequestheader("method", "post"); < 				 	req.setrequestheader("content-length", soapclient.contentlength);					 < 					req.setrequestheader("soapserver", soapclient.soapserver); < 					req.setrequestheader("soapaction", soapreq.action); < 				 } < 			}); --- > 			var xhr = new 
xmlhttprequest(); > 			xhr.mozbackgroundrequest = true; > 			xhr.open('post', soapclient.proxy, true); > 			xhr.onreadystatechange = function() { > 				if (4 != xhr.readystate) { return; } > 				getresponse(xhr); > 			}; > 			var headers = { > 				'method': 'post', > 				'content-type': soapclient.contenttype + '; charset="' + > 					soapclient.charset + '"', > 				'content-length': soapclient.contentlength, > ...
   
 
   
    What XULRunner Provides - Archive of obsolete content
    
the following features are either already implemented or planned: gecko features    xpcom   networking   gecko rendering engine   dom editing and transaction support (no ui)   cryptography   xbl (xbl2 planned)   xul   svg   xslt   xml extras (
xmlhttprequest, domparser, etc.)   web services (soap)   auto-update support (not yet complete)   type ahead find toolbar   history implementation (the places implementation in the 1.9 cycle)   accessibility support   ipc services for communication between gecko-based apps (not yet complete)   storage/sqlite interfaces  user interface features the following user interface is supplied by xulrunner, and may be ov...
   
 
   
   
    2006-10-27 - Archive of obsolete content
    
  discussions  evalinsandbox and 
xmlhttprequest  a discussion about writing something that calls a function defined by the page that the user is currently on   chrome files and last modified date  ways to retrieve the last modified date of a chrome file that may be in a jar or on the file system.
   
 
   
  
   
    2006-11-10 - Archive of obsolete content
    
   discussions  developing an extension like 
xmlhttprequest / nsidocument / mozilla_internal_api a discussion on how to develop an extension similar to 
xmlhttprequest but for a different protocol than http, emulating the asynchronous aspect.
   
 
   
    2006-12-08 - Archive of obsolete content
    
  saving binary data from nsi
xmlhttprequest a discussion on how to use nsi
xmlhttprequest object to query data from a url in an extension implemented in javascript      meetings  none during this week.
   
 
   
    Summary of Changes - Archive of obsolete content
    
http://www.w3.org/tr/2004/rec-dom-le...e3-textcontent              ie5+ elemref.style.pixeltop    dom level 2: parseint(elemref.style.top, 10)           ie5+ elemref.style.pixelleft = x; elemref.style.pixeltop = y;    dom level 2: elemref.style.left = x + "px"; elemref.style.top = y + "px";          ie5+ new activexobject("microsoft.xmlhttp")    new 
xmlhttprequest()          proprietary or deprecated feature    w3c feature or recommended replacement                                         ...
   
 
   
    Using Web Standards in your Web Pages - Archive of obsolete content
    
 contents    benefits of using web standards  making your page using web standards - how to  using the w3c dom  developing cross browser and cross platform pages  using 
xmlhttprequest  summary of changes  references    original document information    author(s): mike cowperthwaite, marcio galli, jim ley, ian oeschger, simon paquet, gérard talbot  last updated date: may 29, 2008  copyright information: portions of this content are © 1998–2008 by individual mozilla.org contributors; content available under a creative commons license | details.
   
 
   
    E4X - Archive of obsolete content
    
  workaround:  var response = 
xmlhttprequest.responsetext; // bug 270553 response = response.replace(/^<\?xml\s+version\s*=\s*(["'])[^\1]+\1[^?]*\?>/, ""); // bug 336551 var e4x = new xml(response);   resources    e4x tutorial processing xml with e4x on mdc  e4x for templating  see the list of e4x-related pages on mdc  ecma-357 standard  brendan's presentation  e4x at faqts.com  e4x quick reference at rephrase.net   ...
   
 
   
   
    Windows Media in Netscape - Archive of obsolete content
    
netscape 7.1 offers its own 
xmlhttprequest object; here is a snippet of cross-browser code that can be used:  if (window.activexobject) {   req = new activexobject("microsoft.xmlhttp"); } else if (window.
xmlhttprequest) {   req = new 
xmlhttprequest(); }  // req can be used in a cross-browser way -- the actual objects are similar // caveat emptor: look out for the case of methods and properties -- ie uses // capital letters where gecko use...
   
 
   
   
    Audio for Web games - Game development
    
 loading your tracks  with the web audio api you can load separate tracks and loops individually using 
xmlhttprequest or the fetch api, which means you can load them synchronously or in parallel.
   
 
   
   
   
   
   
   
    MDN Web Docs Glossary: Definitions of Web-related terms
    
  wai          wcag          web performance          web server          web standards          webassembly          webdav          webextensions          webgl          webidl          webkit          webm          webp          webrtc          websockets          webvtt          whatwg          whitespace          world wide web          wrapper            x               xforms          xhr (
xmlhttprequest)          xhtml          xinclude          xlink          xml          xpath          xquery          xslt            other               404          502                  alpn          at-rule          attack          byte-order mark          character set          client          cryptosystem          debug          digital signature          execution          flex-direction          glsl     ...
   
 
   
  
   
   
    Choosing the right approach - Learn web development
    
        single delayed operation    repeating operation    multiple sequential operations    multiple simultaneous operations              no    yes (recursive callbacks)    yes (nested callbacks)    no        code example  an example that loads a resource via the 
xmlhttprequest api (run it live, and see the source):  function loadasset(url, type, callback) {   let xhr = new 
xmlhttprequest();   xhr.open('get', url);   xhr.responsetype = type;    xhr.onload = function() {     callback(xhr.response);   };    xhr.send(); }  function displayimage(blob) {   let objecturl = url.createobjecturl(blob);    let image = document.createelement('img');   image.src = objecturl;   docu...
   
 
   
   
   
    Http.jsm
    
        http.jsm  http.jsm provides httprequest - a wrapper for 
xmlhttprequest that provides convenient and simplified api for dealing with http requests.
   
 
   
    WebRequest.jsm
    
 the following types are supported:           "main_frame"          "sub_frame"          "stylesheet"          "script"          "image"          "object"          "
xmlhttprequest"        http headers  https headers are represented as objects with two properties, name and value:           name    type    description              name    string    header name, for example "content-type"          value    string    header value, for example "image/png"        chrome incompatibilities  although this api is modeled on chrome's webrequest extension api, there are some differenc...
   
 
   
    JavaScript code modules
    
 http.jsm  a wrapper for 
xmlhttprequest that provides convenient and simplified api for dealing with http requests.
   
 
   
    Mozilla DOM Hacking Guide
    
 there are two other similar macros:  #define dom_classinfo_map_begin_no_primary_interface(_class) _dom_classinfo_map_begin(_class, nsnull, pr_true)   this macro is used if the dom class (for example 
xmlhttprequest) does not have any interface, yet you want the 
xmlhttprequest object to be available from javascript.
   
 
   
   
    JSAPI User Guide
    
 the word javascript may bring to mind features such as event handlers (like onclick), dom objects, window.open, and 
xmlhttprequest.
   
 
   
    Components.utils.Sandbox
    
 the following objects are supported:                -promise (removed in firefox 37)             css             indexeddb (web worker only)             
xmlhttprequest             textencoder             textdecoder             url             urlsearchparams             atob             btoa             blob             file             crypto             rtcidentityprovider             fetch (added in firefox 41)             caches             filereader            for example:   var sandboxscript = 'var encoded = btoa("hello");' +                     'var de...
   
 
   
    nsIDocShell
    
all values from here upward are confident enough to be used for 
xmlhttprequest.
   
 
   
    nsIPushSubscription
    
es: cc, interfaces: ci, utils: cu } = components;  const scriptsecuritymanager = cc["@mozilla.org/scriptsecuritymanager;1"]                                 .getservice(ci.nsiscriptsecuritymanager); const pushservice = cc["@mozilla.org/push/service;1"]                       .getservice(ci.nsipushservice);  function sendsubscriptiontoserver(subscription) {   let request = cc["@mozilla.org/xmlextras/
xmlhttprequest;1"]                   .createinstance(ci.nsi
xmlhttprequest);   request.open("post", "https://example.com/register-for-push", true);   request.addeventlistener("error", () => {     cu.reporterror("error sending subscription to server");   });   request.send(json.stringify({     endpoint: subscription.endpoint,      // base64-encode the key and authentication secret.
   
 
   
    nsITraceableChannel
    
to 
xmlhttprequest or to the browser tab that made the request) with your own implementation (see "implementing nsistreamlistener" below).
   
 
   
    XPCOM Interface Reference
    
portnsiwifiaccesspointnsiwifilistenernsiwifimonitornsiwinaccessnodensiwinapphelpernsiwintaskbarnsiwindowcreatornsiwindowmediatornsiwindowwatchernsiwindowsregkeynsiwindowsshellservicensiworkernsiworkerfactorynsiworkerglobalscopensiworkermessageeventnsiworkermessageportnsiworkerscopensiwritablepropertybagnsiwritablepropertybag2nsixformsmodelelementnsixformsnsinstanceelementnsixformsnsmodelelementnsi
xmlhttprequestnsi
xmlhttprequesteventtargetnsi
xmlhttprequestuploadnsixpcexceptionnsixpcscriptablensixpconnectnsixsltexceptionnsixsltprocessornsixsltprocessorobsoletensixulappinfonsixulbrowserwindownsixulbuilderlistenernsixulruntimensixulsortservicensixultemplatebuildernsixultemplatequeryprocessornsixultemplateresultnsixulwindownsixmlrpcclientnsixmlrpcfaultnsizipentrynsizipreadernsizipreadercachensizipwriternsmsg...
   
 
   
  
   
    Setting HTTP request headers
    
you can add your own http headers to any request the application makes, whether the request is initiated by your code explicitly opening an http channel, because of 
xmlhttprequest activity, an <img> element in content, or even from css.
   
 
   
    Mozilla
    
                     xmlhttprequest changes for gecko1.8                       this document describes some of the changes that have been made to gecko's 
xmlhttprequest implementation since version 1.7 (i.e., the version of gecko that            shipped with firefox 1.0).
   
 
   
   
   
   
    Network Monitor - Firefox Developer Tools
    
 the network monitor shows you all the network requests firefox makes (for example, when it loads a page, or due to 
xmlhttprequests), how long each request takes, and details of each request.
   
 
   
   
   
    AudioBufferSourceNode.loop - Web APIs
    
  you can run the full example live (or view the source.)   function getdata() {   source = audioctx.createbuffersource();   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';    request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {         mybuffer = buffer;         source.buffer = mybuffer;         source.playbackrate.value = playbackcontrol.value;         source.connect(audioctx.destination);         source.
   
 
   
    AudioBufferSourceNode.loopEnd - Web APIs
    
  function getdata() {   source = audioctx.createbuffersource();   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';     request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {         mybuffer = buffer;         songlength = buffer.duration;         source.buffer = mybuffer;         source.playbackrate.value = playbackcontrol.value;         source.connect...
   
 
   
    AudioBufferSourceNode.loopStart - Web APIs
    
  function getdata() {   source = audioctx.createbuffersource();   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';    request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {         mybuffer = buffer;         songlength = buffer.duration;         source.buffer = mybuffer;         source.playbackrate.value = playbackcontrol.value;         source.connect(a...
   
 
   
    AudioBufferSourceNode.playbackRate - Web APIs
    
  <input class="playback-rate-control" type="range" min="0.25" max="3" step="0.05" value="1"> <span class="playback-rate-value">1.0</span>   function getdata() {   source = audioctx.createbuffersource();   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';    request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {         mybuffer = buffer;         source.buffer = mybuffer;         source.playbackrate.value = playbackcontrol.value;         source.connect(audioctx.destination);         source.
   
 
   
    AudioProcessingEvent - Web APIs
    
create audiocontext and buffer source var audioctx = new audiocontext(); source = audioctx.createbuffersource();  // create a scriptprocessornode with a buffersize of 4096 and a single input and output channel var scriptnode = audioctx.createscriptprocessor(4096, 1, 1); console.log(scriptnode.buffersize);  // load in an audio track via xhr and decodeaudiodata  function getdata() {   request = new 
xmlhttprequest();   request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';   request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {     mybuffer = buffer;        source.buffer = mybuffer;   },     function(e){"error with decoding audio data" + e.err});   }   request.send(); }  // give the node a function to process...
   
 
   
    BaseAudioContext.createConvolver() - Web APIs
    
 // grab audio track via xhr for convolver node  var soundsource, concerthallbuffer;  ajaxrequest = new 
xmlhttprequest(); ajaxrequest.open('get', 'concert-crowd.ogg', true); ajaxrequest.responsetype = 'arraybuffer';  ajaxrequest.onload = function() {   var audiodata = ajaxrequest.response;   audioctx.decodeaudiodata(audiodata, function(buffer) {       concerthallbuffer = buffer;       soundsource = audioctx.createbuffersource();       soundsource.buffer = concerthallbuffer;     }, function(e){"error with decoding...
   
 
   
    BaseAudioContext.createScriptProcessor() - Web APIs
    
create audiocontext and buffer source var audioctx = new audiocontext(); source = audioctx.createbuffersource();  // create a scriptprocessornode with a buffersize of 4096 and a single input and output channel var scriptnode = audioctx.createscriptprocessor(4096, 1, 1); console.log(scriptnode.buffersize);  // load in an audio track via xhr and decodeaudiodata  function getdata() {   request = new 
xmlhttprequest();   request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';   request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {     mybuffer = buffer;        source.buffer = mybuffer;   },     function(e){"error with decoding audio data" + e.err});   }   request.send(); }  // give the node a function to process...
   
 
   
  
   
    BaseAudioContext - Web APIs
    
in this case, the arraybuffer is usually loaded from an 
xmlhttprequest's response attribute after setting the responsetype to arraybuffer.
   
 
   
    ConvolverNode.buffer - Web APIs
    
 // grab audio track via xhr for convolver node  var soundsource, concerthallbuffer;  ajaxrequest = new 
xmlhttprequest(); ajaxrequest.open('get', 'concert-crowd.ogg', true); ajaxrequest.responsetype = 'arraybuffer';  ajaxrequest.onload = function() {   var audiodata = ajaxrequest.response;   audioctx.decodeaudiodata(audiodata, function(buffer) {       concerthallbuffer = buffer;       soundsource = audioctx.createbuffersource();       soundsource.buffer = concerthallbuffer;     }, function(e){"error with decoding...
   
 
   
    ConvolverNode.normalize - Web APIs
    
 // grab audio track via xhr for convolver node  var soundsource, concerthallbuffer;  ajaxrequest = new 
xmlhttprequest(); ajaxrequest.open('get', 'concert-crowd.ogg', true); ajaxrequest.responsetype = 'arraybuffer';  ajaxrequest.onload = function() {   var audiodata = ajaxrequest.response;   audioctx.decodeaudiodata(audiodata, function(buffer) {       concerthallbuffer = buffer;       soundsource = audioctx.createbuffersource();       soundsource.buffer = concerthallbuffer;     }, function(e){"error with decoding...
   
 
   
    DOMParser - Web APIs
    
  note: 
xmlhttprequest can parse xml and html directly from a url-addressable resource, returning a document in its response property.
   
 
   
    Document.lastModified - Web APIs
    
(see: bug 4363 – document.lastmodified returns date in utc time, but should return it in local time)  if you want to know whether an external page has changed, please read this paragraph about the 
xmlhttprequest() api.
   
 
   
    How to create a DOM tree - Web APIs
    
 dom trees can be  queried using xpath expressions, converted to strings or written to a local or remote files using  xmlserializer (without having to first convert to a string), posted to a web server (via 
xmlhttprequest), transformed using xslt, xlink, converted to a javascript object through a jxon algorithm, etc.
   
 
   
   
   
   
    Fetch API - Web APIs
    
it will seem familiar to anyone who has used 
xmlhttprequest, but the new api provides a more powerful and flexible feature set.
   
 
   
    File - Web APIs
    
in particular, filereader, url.createobjecturl(), createimagebitmap(), and 
xmlhttprequest.send() accept both blobs and files.
   
 
   
    FileHandle API - Web APIs
    
for example, there are many apis that expect blob or file objects such as filereader (which can be easier to use to read the whole file) or 
xmlhttprequest.
   
 
   
    Introduction to the File and Directory Entries API - Web APIs
    
for example, you are likely to use one of the following:   	
xmlhttprequest (such as the send() method for file and blob objects) 	drag and drop api 	web workers (for the synchronous version of the file and directory entries api) 	the input element (to programmatically obtain a list of files from the element)   the file and directory entries api is case sensitive  the filesystem api is case-sensitive, and case-preserving.
   
 
   
    FormData() - Web APIs
    
  let myform = document.getelementbyid('myform'); let formdata = new formdata(myform);  specifications           specification    status    comment          
xmlhttprequestthe definition of 'formdata()' in that specification.
   
 
   
    FormData.append() - Web APIs
    
 if the sent value is different than string or blob it will be automatically converted to string:  formdata.append('name', true); formdata.append('name', 74); formdata.append('name', 'john');  formdata.getall('name'); // ["true", "74", "john"]   specifications           specification    status    comment          
xmlhttprequestthe definition of 'append()' in that specification.
   
 
   
  
   
    FormData.delete() - Web APIs
    
 example  the following line creates an empty formdata object and prepopulates it with key/value pairs from a form:  var formdata = new formdata(myform);  you can delete keys and their values using delete():  formdata.delete('username');   specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequestthe definition of 'delete()' in that specification.
   
 
   
    FormData.entries() - Web APIs
    
 example  // create a test formdata object var formdata = new formdata(); formdata.append('key1', 'value1'); formdata.append('key2', 'value2');  // display the key/value pairs for(var pair of formdata.entries()) {    console.log(pair[0]+ ', '+ pair[1]); }   the result is:  key1, value1 key2, value2  specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequestthe definition of 'entries() (as iterator<>)' in that specification.
   
 
   
    FormData.get() - Web APIs
    
g line creates an empty formdata object:  var formdata = new formdata();  if we add two username values using formdata.append:  formdata.append('username', 'chris'); formdata.append('username', 'bob');  the following get() function will only return the first username value appended:  formdata.get('username'); // returns "chris"  specifications           specification    status    comment          
xmlhttprequestthe definition of 'get()' in that specification.
   
 
   
    FormData.getAll() - Web APIs
    
eates an empty formdata object:  var formdata = new formdata();  if we add two username values using formdata.append:  formdata.append('username', 'chris'); formdata.append('username', 'bob');  the following getall() function will return both username values in an array:  formdata.getall('username'); // returns ["chris", "bob"]  specifications           specification    status    comment          
xmlhttprequestthe definition of 'getall()' in that specification.
   
 
   
    FormData.has() - Web APIs
    
ormdata = new formdata();  the following snippet shows the results of testing for the existence of username in the formdata object, before and after appending a username value to it with formdata.append:  formdata.has('username'); // returns false formdata.append('username', 'chris'); formdata.has('username'); // returns true    specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequestthe definition of 'has()' in that specification.
   
 
   
    FormData.keys() - Web APIs
    
 example  // create a test formdata object var formdata = new formdata(); formdata.append('key1', 'value1'); formdata.append('key2', 'value2');  // display the keys for (var key of formdata.keys()) {    console.log(key); }   the result is:  key1 key2  specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequestthe definition of 'keys() (as iterator<>)' in that specification.
   
 
   
    FormData.set() - Web APIs
    
); // currently empty  you can set key/value pairs on this using formdata.set:  formdata.set('username', 'chris'); formdata.set('userpic', myfileinput.files[0], 'chris.jpg');  if the sent value is different than string or blob it will be automatically converted to string:  formdata.set('name', 72); formdata.get('name'); // "72"  specifications           specification    status    comment          
xmlhttprequestthe definition of 'set()' in that specification.
   
 
   
    FormData.values() - Web APIs
    
 example  // create a test formdata object var formdata = new formdata(); formdata.append('key1', 'value1'); formdata.append('key2', 'value2');  // display the values for (var value of formdata.values()) {    console.log(value); }   the result is:  value1 value2  specifications   	 		 			specification 			status 			comment 		 		 			
xmlhttprequestthe definition of 'values() (as iterator<>)' in that specification.
   
 
   
    FormDataEvent.formData - Web APIs
    
  // construct a formdata object, which fires the formdata event   new formdata(formelem); });  // formdata handler to retrieve data  formelem.addeventlistener('formdata', (e) => {   console.log('formdata fired');    // get the form data from the event object   let data = e.formdata;   for (var value of data.values()) {     console.log(value);   }    // submit the data via xhr   var request = new 
xmlhttprequest();   request.open("post", "/formhandler");   request.send(data); });  specifications           specification    status    comment          html living standardthe definition of 'formdata' in that specification.
   
 
   
    GlobalEventHandlers.onformdata - Web APIs
    
ventdefault();    // construct a formdata object, which fires the formdata event   new formdata(formelem); });  // formdata handler to retrieve data  formelem.onformdata = (e) => {   console.log('formdata fired');    // get the form data from the event object   let data = e.formdata;   for (var value of data.values()) {     console.log(value);   }    // submit the data via xhr   var request = new 
xmlhttprequest();   request.open("post", "/formhandler");   request.send(data); };  specifications           specification    status    comment          html living standardthe definition of 'onformdata' in that specification.
   
 
   
    GlobalEventHandlers.onload - Web APIs
    
 the onload property of the globaleventhandlers mixin is an eventhandler that processes load events on a window, 
xmlhttprequest, <img> element, etc.
   
 
   
    HTMLFormElement: formdata event - Web APIs
    
  // construct a formdata object, which fires the formdata event   new formdata(formelem); });  // formdata handler to retrieve data  formelem.addeventlistener('formdata', (e) => {   console.log('formdata fired');    // get the form data from the event object   let data = e.formdata;   for (var value of data.values()) {     console.log(value);   }    // submit the data via xhr   var request = new 
xmlhttprequest();   request.open("post", "/formhandler");   request.send(data); });  the onformdata version would look like this:  formelem.onformdata = (e) => {   console.log('formdata fired');    // get the form data from the event object   let data = e.formdata;   for (var value of data.values()) {     console.log(value);   }    // submit the data via xhr   var request = new 
xmlhttprequest();   request.open(...
   
 
   
    HTMLFormElement - Web APIs
    
me="pet" value="dog"> dog</label></p>   </fieldset>    <fieldset>     <legend>owned vehicles</legend>      <p><label><input type="checkbox" name="vehicle" value="bike">i have a bike</label></p>     <p><label><input type="checkbox" name="vehicle" value="car">i have a car</label></p>   </fieldset>    <p><button>submit</button></p> </form>  </body> </html>  submitting forms and uploading files using 
xmlhttprequest  if you want to know how to serialize and submit a form using the 
xmlhttprequest api, please read this paragraph.
   
 
   
    Ajax navigation example - Web APIs
    
"&" + sviewkey + "=" + sviewmode : "").slice(1)).replace(rendqstmark, "");     }      function getpage (spage) {         if (bisloading) { return; }         oreq = new 
xmlhttprequest();         bisloading = true;         oreq.onload = ajaxload;         oreq.onerror = ajaxerror;         if (spage) { opageinfo.url = filterurl(spage, null); }         oreq.open("get", filterurl(opageinfo.url, "json"), true);         oreq.send();         oloadingbox.parentnode || document.body.appendchild(oloadingbox);     }      function requestpage (surl) {         if (history.pushstate) {      ...
   
 
   
   
  
   
    Using IndexedDB - Web APIs
    
   */   function addpublicationfromurl(biblioid, title, year, url) {     console.log("addpublicationfromurl:", arguments);      var xhr = new 
xmlhttprequest();     xhr.open('get', url, true);     // setting the wanted responsetype to "blob"     // http://www.w3.org/tr/
xmlhttprequest2/#the-response-attribute     xhr.responsetype = 'blob';     xhr.onload = function (evt) {       if (xhr.status == 200) {         console.log("blob retrieved");         var blob = xhr.response;         console.log("blob:", blob);         addpublication(biblioid, title, yea...
   
 
   
    MediaSource.endOfStream() - Web APIs
    
when you make an 
xmlhttprequest call for a media chunk, and onabort or onerror triggers, you might want to call endofstream('network'), display a descriptive message in the ui, and maybe retry the network request immediately or wait until the network is back up (via some kind of polling.)   decode: terminates playback and signals that a decoding error has occured.
   
 
   
    Navigation Timing API - Web APIs
    
  concepts and usage  you can use the navigation timing api to gather performance data on the client side, which you can then transmit to a server using 
xmlhttprequest or other techniques.
   
 
   
    Online and offline events - Web APIs
    
background: red; }   and the corresponding htmlxxx when mochitests for this are created, point to those instead and update this example -nickolay  <div id="status"></div> <div id="log"></div> <p>this is a test</p>   here's the live result    notes  if the api isn't implemented in the browser, you can use other signals to detect if you are offline including using service workers and responses from 
xmlhttprequest.
   
 
   
    OfflineAudioContext.startRendering() - Web APIs
    
offline-audio-context-promise github repo (see the source code too.)   // define online and offline audio context  var audioctx = new audiocontext(); var offlinectx = new offlineaudiocontext(2,44100*40,44100);  source = offlinectx.createbuffersource();  // use xhr to load an audio track, and // decodeaudiodata to decode it and offlineaudiocontext to render it  function getdata() {   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';    request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {       mybuffer = buffer;       source.buffer = mybuffer;       source.connect(offlinectx.destination);       source.start();       //source.loop = true;       offlinectx.startrender...
   
 
   
    OfflineAudioContext - Web APIs
    
offline-audio-context-promise github repo (see the source code too.)   // define online and offline audio context  var audioctx = new audiocontext(); var offlinectx = new offlineaudiocontext(2,44100*40,44100);  source = offlinectx.createbuffersource();  // use xhr to load an audio track, and // decodeaudiodata to decode it and offlineaudiocontext to render it  function getdata() {   request = new 
xmlhttprequest();    request.open('get', 'viper.ogg', true);    request.responsetype = 'arraybuffer';    request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {       mybuffer = buffer;       source.buffer = mybuffer;       source.connect(offlinectx.destination);       source.start();       //source.loop = true;       offlinectx.startrender...
   
 
   
   
    PerformanceResourceTiming - Web APIs
    
an application can use the timing metrics to determine, for example, the length of time it takes to fetch a specific resource, such as an 
xmlhttprequest, <svg>, image, or script.
   
 
   
    ProgressEvent() - Web APIs
    
  specifications           specification    status    comment          
xmlhttprequestthe definition of 'progressevent()' in that specification.
   
 
   
    ProgressEvent.lengthComputable - Web APIs
    
 syntax  flag = progressevent.lengthcomputable  specifications           specification    status    comment          
xmlhttprequestthe definition of 'progressevent.lengthcomputable' in that specification.
   
 
   
    ProgressEvent.loaded - Web APIs
    
 syntax  value = progressevent.loaded  specifications           specification    status    comment          
xmlhttprequestthe definition of 'progressevent.loaded' in that specification.
   
 
   
    ProgressEvent.total - Web APIs
    
 syntax  value = progressevent.total  specifications           specification    status    comment          
xmlhttprequestthe definition of 'progressevent.lengthcomputable' in that specification.
   
 
   
    PushManager.subscribe() - Web APIs
    
 = {       uservisibleonly: true,       applicationserverkey: applicationserverkey     };     serviceworkerregistration.pushmanager.subscribe(options).then(       function(pushsubscription) {         console.log(pushsubscription.endpoint);         // the push subscription details needed by the application         // server are now available, and can be sent to it using,         // for example, an 
xmlhttprequest.
   
 
   
    PushManager - Web APIs
    
vigator.serviceworker.register('serviceworker.js').then(   function(serviceworkerregistration) {     serviceworkerregistration.pushmanager.subscribe().then(       function(pushsubscription) {         console.log(pushsubscription.endpoint);         // the push subscription details needed by the application         // server are now available, and can be sent to it using,         // for example, an 
xmlhttprequest.
   
 
   
   
  
   
    Using the Resource Timing API - Web APIs
    
an application can use the timing metrics to determine, for example, the length of time it takes to fetch a specific resource such as an 
xmlhttprequest, <svg>, image, script, etc.).
   
 
   
    ScriptProcessorNode.bufferSize - Web APIs
    
create audiocontext and buffer source var audioctx = new audiocontext(); source = audioctx.createbuffersource();  // create a scriptprocessornode with a buffersize of 4096 and a single input and output channel var scriptnode = audioctx.createscriptprocessor(4096, 1, 1); console.log(scriptnode.buffersize);  // load in an audio track via xhr and decodeaudiodata  function getdata() {   request = new 
xmlhttprequest();   request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';   request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {     mybuffer = buffer;     source.buffer = mybuffer;   },     function(e){"error with decoding audio data" + e.err});   }   request.send(); }  // give the node a function to process au...
   
 
   
    ScriptProcessorNode.onaudioprocess - Web APIs
    
create audiocontext and buffer source var audioctx = new audiocontext(); source = audioctx.createbuffersource();  // create a scriptprocessornode with a buffersize of 4096 and a single input and output channel var scriptnode = audioctx.createscriptprocessor(4096, 1, 1); console.log(scriptnode.buffersize);  // load in an audio track via xhr and decodeaudiodata  function getdata() {   request = new 
xmlhttprequest();   request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';   request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {     mybuffer = buffer;        source.buffer = mybuffer;   },     function(e){"error with decoding audio data" + e.err});   }   request.send(); }  // give the node a function to process...
   
 
   
    ScriptProcessorNode - Web APIs
    
create audiocontext and buffer source var audioctx = new audiocontext(); source = audioctx.createbuffersource();  // create a scriptprocessornode with a buffersize of 4096 and a single input and output channel var scriptnode = audioctx.createscriptprocessor(4096, 1, 1); console.log(scriptnode.buffersize);  // load in an audio track via xhr and decodeaudiodata  function getdata() {   request = new 
xmlhttprequest();   request.open('get', 'viper.ogg', true);   request.responsetype = 'arraybuffer';   request.onload = function() {     var audiodata = request.response;      audioctx.decodeaudiodata(audiodata, function(buffer) {     mybuffer = buffer;     source.buffer = mybuffer;   },     function(e){"error with decoding audio data" + e.err});   }   request.send(); }  // give the node a function to process au...
   
 
   
    ServiceWorkerRegistration.pushManager - Web APIs
    
n(   function(serviceworkerregistration) {     serviceworkerregistration.pushmanager.subscribe().then(       function(pushsubscription) {         console.log(pushsubscription.subscriptionid);         console.log(pushsubscription.endpoint);         // the push subscription details needed by the application         // server are now available, and can be sent to it using,         // for example, an 
xmlhttprequest.
   
 
   
    SourceBuffer - Web APIs
    
source = this;   var sourcebuffer = mediasource.addsourcebuffer(mimecodec);   fetchab(asseturl, function (buf) {     sourcebuffer.addeventlistener('updateend', function (_) {       mediasource.endofstream();       video.play();       //console.log(mediasource.readystate); // ended     });     sourcebuffer.appendbuffer(buf);   }); }  function fetchab (url, cb) {   console.log(url);   var xhr = new 
xmlhttprequest;   xhr.open('get', url);   xhr.responsetype = 'arraybuffer';   xhr.onload = function () {     cb(xhr.response);   };   xhr.send(); }  specifications           specification    status    comment          media source extensionsthe definition of 'sourcebuffer' in that specification.
   
 
   
    Lifetime of a WebRTC session - Web APIs
    
 in order to exchange signaling information, you can choose to send json objects back and forth over a websocket connection, or you could use xmpp or sip over an appropriate channel, or you could use 
xmlhttprequest over https with polling, or any other combination of technologies you can come up with.
   
 
   
   
    Web Workers API - Web APIs
    
 in addition, workers may use 
xmlhttprequest for network i/o, with the exception that the responsexml and channel attributes on 
xmlhttprequest always return null.
   
 
   
    Worker - Web APIs
    
workers may use 
xmlhttprequest for network communication, but its responsexml and channel attributes are always null.
   
 
   
    XDomainRequest - Web APIs
    
it was removed in internet explorer 10 in favor of using 
xmlhttprequest with proper cors; if you are targeting internet explorer 10 or later, or wish to support any other browser, you need to use standard http access control.
   
 
   
    XMLDocument.load() - Web APIs
    
as of at least gecko 1.9, this no longer supports cross-site loading of documents (use 
xmlhttprequest or fetch() instead).
   
 
   
    msCaching - Web APIs
    
        the mscaching read/write property specifies whether stream data downloaded using 
xmlhttprequestis cached to disk or not.
   
 
   
    Web APIs
    
glshaderprecisionformat webglsync   webgltexture webgltransformfeedback webgluniformlocation webglvertexarrayobject webkitcssmatrix websocket wheelevent window windowclient   windoweventhandlers windoworworkerglobalscope worker workerglobalscope workerlocation workernavigator worklet   writablestream   writablestreamdefaultcontroller   writablestreamdefaultwriter    x xdomainrequest   xmldocument 
xmlhttprequest xmlhttprequesteventtarget 
xmlhttprequestresponsetype xmlserializer xpathevaluator xpathexception xpathexpression xpathnsresolver xpathresult xrboundedreferencespace xrenvironmentblendmode xreye xrframe xrframerequestcallback xrhandedness xrinputsource   xrinputsourcearray xrinputsourceevent xrinputsourceeventinit xrinputsourceschangeevent xrinputsourceschangeeventinit xrpermissiondescriptor xrper...
   
 
   
    ARIA: form role - Accessibility
    
anything that is not a <form> cannot be submitted, therefore you would have to use javascript to build an alternative data submission mechanism, for example with 
xmlhttprequest.
   
 
   
  
   
   
    Audio and Video Delivery - Developer guides
    
 web audio api    var context;   var request;   var source;    try {     context = new audiocontext();     request = new 
xmlhttprequest();     request.open("get","http://jplayer.org/audio/mp3/riomez-01-sleep_together.mp3",true);     request.responsetype = "arraybuffer";      request.onload = function() {       context.decodeaudiodata(request.response, function(buffer) {         source = context.createbuffersource();         source.buffer = buffer;         source.connect(context.destination);         // auto play         source.st...
   
 
   
    Overview of events and handlers - Developer guides
    
ent kinds based on the object emitting the event including:    the window object, such as due to resizing the browser,  the window.screen object, such as due to changes in device orientation,  the document object, including the loading, modification, user interaction, and unloading of the page,  the objects in the dom (document object model) tree including user interactions or modifications,  the 
xmlhttprequest objects used for network requests, and  the media objects such as audio and video, when the media stream players change state.
   
 
   
    HTML5 - Developer guides
    
 xmlhttprequest level 2  allows fetching asynchronously some parts of the page, allowing it to display dynamic content, varying according to the time and user actions.
   
 
   
    Developer guides
    
 using formdata objects  the formdata object lets you compile a set of key/value pairs to send using 
xmlhttprequest.
   
 
   
   
   
    Reason: CORS request not HTTP - HTTP
    
 to fix this problem, simply make sure you use https urls when issuing requests involving cors, such as 
xmlhttprequest, fetch apis, web fonts (@font-face), and webgl textures, and xsl stylesheets.
   
 
   
    Using Feature Policy - HTTP
    
these features include:    layout-inducing animations  unoptimized (poorly compressed) images  oversized images  synchronous scripts  synchronous 
xmlhttprequest  unsized media   to avoid breaking existing web content, the default for such policy-controlled features is to allow the functionality to be used by all origins.
   
 
   
    Feature Policy - HTTP
    
 the features include:    layout-inducing animations  legacy image formats  oversized images  synchronous scripts  synchronous 
xmlhttprequest  unoptimized images  unsized media   granular control over certain features  the web provides functionality and apis that may have privacy or security risks if abused.
   
 
   
    Feature-Policy: sync-xhr - HTTP
    
   the http feature-policy header sync-xhr directive controls whether the current document is allowed to make synchronous 
xmlhttprequest requests.
   
 
   
    Feature-Policy - HTTP
    
 sync-xhr  controls whether the current document is allowed to make synchronous 
xmlhttprequest requests.
   
 
   
   
    POST - HTTP
    
 text/plain   when the post request is sent via a method other than an html form — like via an 
xmlhttprequest — the body can take any type.
   
 
   
    An overview of HTTP - HTTP
    
  apis based on http  the most commonly used api based on http is the 
xmlhttprequest api, which can be used to exchange data between a user agent and a server.
   
 
   
  
   
    Protocol upgrade mechanism - HTTP
    
in essence, then, this key simply confirms that "yes, i really mean to open a websocket connection."  this header is automatically added by clients that choose to use it; it cannot be added using the 
xmlhttprequest.setrequestheader() method.
   
 
   
    A typical HTTP session - HTTP
    
to work around this problem, web developers use several techniques: ping the server periodically via the 
xmlhttprequest, fetch apis, using the websockets api, or similar protocols.
   
 
   
   
   
    Promise() constructor - JavaScript
    
solve, reject) => {   // do something asynchronous which eventually calls either:   //   //   resolve(somevalue)        // fulfilled   // or   //   reject("failure reason")  // rejected });   making functions return a promise  to provide a function with promise functionality, have it return a promise:  function myasyncfunction(url) {   return new promise((resolve, reject) => {     const xhr = new 
xmlhttprequest()     xhr.open("get", url)     xhr.onload = () => resolve(xhr.responsetext)     xhr.onerror = () => reject(xhr.statustext)     xhr.send()   }); }  specifications           specification          ecmascript (ecma-262)the definition of 'promise constructor' in that specification.
   
 
   
    Promise - JavaScript
    
   loading an image with xhr  another simple example using promise and 
xmlhttprequest to load an image is available at the mdn github js-examples repository.
   
 
   
    encodeURI() - JavaScript
    
!~*'() console.log(encodeuri(set3)); // abc%20abc%20123 (the space gets encoded as %20)  console.log(encodeuricomponent(set1)); // %3b%2c%2f%3f%3a%40%26%3d%2b%24%23 console.log(encodeuricomponent(set2)); // -_.!~*'() console.log(encodeuricomponent(set3)); // abc%20abc%20123 (the space gets encoded as %20)   note that encodeuri() by itself cannot form proper http get and post requests, such as for 
xmlhttprequest, because "&", "+", and "=" are not encoded, which are treated as special characters in get and post requests.
   
 
   
    import - JavaScript
    
 the module: file.js  function getjson(url, callback) {   let xhr = new 
xmlhttprequest();   xhr.onload = function () {     callback(this.responsetext)   };   xhr.open('get', url, true);   xhr.send(); }  export function getusefulcontents(url, callback) {   getjson(url, data => callback(json.parse(data))); }  the main program: main.js  import { getusefulcontents } from '/modules/file.js';  getusefulcontents('http://www.example.com',     data => { dosomethinguseful(data); });  dynamic...
   
 
   
   
    Mixed content - Web security
    
 active content examples  this section lists some types of http requests which are considered active content:    <script> (src attribute)  <link> (href attribute) (this includes css stylesheets)  <iframe> (src attribute)  
xmlhttprequest requests  fetch() requests  all cases in css where a <url> value is used (@font-face, cursor, background-image, and so forth).
   
 
   
    Same-origin policy - Web security
    
  cross-origin network access  the same-origin policy controls interactions between two different origins, such as when you use 
xmlhttprequest or an <img> element.
   
 
   
    XPath snippets - XPath
    
 if you are using 
xmlhttprequest to read a local or remote xml file into a dom tree (as described in parsing and serializing xml), the first argument to evaluatexpath() should be req.responsexml.
   
 
   
   
    Advanced Example - XSLT: Extensible Stylesheet Language Transformations
    
  <div id="example">   <div>1</div>   <div>2</div>   <div>3</div>   <div>4</div>   <div>5</div>   <div>6</div>   <div>7</div>   <div>8</div>   <div>9</div>   <div>10</div> </div>  // javascript  var xslref; var xslloaded = false; var xsltprocessor = new xsltprocessor(); var mydom;  var xmlref = document.implementation.createdocument("", "", null);  function sort() {   if (!xslloaded){     p = new 
xmlhttprequest();     p.open("get", "example2.xsl", false);     p.send(null);      xslref = p.responsexml;     xsltprocessor.importstylesheet(xslref);     xslloaded = true;   }    // create a new xml document in memory   xmlref = document.implementation.createdocument("", "", null);    // we want to move a part of the dom from an html document to an xml document.
   
 
   
    Index - WebAssembly
    
       8     index     index, webassembly       found 12 pages:        9     loading and running webassembly code     fetch, javascript, webassembly, 
xmlhttprequest, bytecode       to use webassembly in javascript, you first need to pull your module into memory before compilation/instantiation.