Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

XMLHttpRequest module not defined/found

This is my code:

var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
var xhr = new XMLHttpRequest();
xhr.open("GET", "//URL")
xhr.setRequestHeader("Content-Type: application/json", "Authorization: Basic //AuthKey");
xhr.send();

I am getting the error:

Cannot find module 'xmlhttprequest'

When I remove the first line, I am getting:

XMLHttpRequest is not defined

I have searched all over and people have mentioned a problem with Node.js here and there but my installation of Node was correct so I'm not sure what the issue is.

like image 943
wmash Avatar asked Sep 16 '15 09:09

wmash


3 Answers

XMLHttpRequest is a built-in object in web browsers.

It is not distributed with Node. The http module is the built-in tool for making HTTP requests from Node.

Most people making HTTP requests from node use a third party library with a friendlier API. Two popular choices are Axios (for use both in Node.js and browsers) and node-fetch (which implements the fetch API which is built into browsers and is a modern replacement for XMLHttpRequest.

2022 update: Node 18 has a native implementation of fetch enabled by default.

If you really want to use XHR in Node.js then there are a couple of third party implementations. xmlhttprequest (which seems to be unmaintained) and xhr2 (which had an update when I added it to this answer but seems to have been abandoned by the developer since).

  1. Install it with npm,

     npm install xhr2
    
  2. Now you can require it in your code.

     var XMLHttpRequest = require('xhr2');
     var xhr = new XMLHttpRequest();
    
like image 93
Quentin Avatar answered Nov 15 '22 17:11

Quentin


Since the last update of the xmlhttprequest module was around 2 years ago, in some cases it does not work as expected.

So instead, you can use the xhr2 module. In other words:

var XMLHttpRequest = require("xmlhttprequest").XMLHttpRequest;
var xhr = new XMLHttpRequest();

becomes:

var XMLHttpRequest = require('xhr2');
var xhr = new XMLHttpRequest();

But ... of course, there are more popular modules like Axios, because -for example- uses promises:

// Make a request for a user with a given ID
axios.get('/user?ID=12345').then(function (response) {
    console.log(response);
}).catch(function (error) {
    console.log(error);
});
like image 30
robe007 Avatar answered Nov 15 '22 19:11

robe007


With the xhr2 library you can globally overwrite XMLHttpRequest from your JS code. This allows you to use external libraries in node, that were intended to be run from browsers / assume they are run in a browser.

global.XMLHttpRequest = require('xhr2');
like image 11
Rok Povsic Avatar answered Nov 15 '22 19:11

Rok Povsic