node:ReferenceError: XMLHttpRequest is not defined

node:ReferenceError: XMLHttpRequest is not defined

1 前言

node执行如下代码:

javascript 复制代码
new XMLHttpRequest()

报错提示:ReferenceError: XMLHttpRequest is not defined

2 解决

2.1 可能原因是没有安装xmlhttprequest

javascript 复制代码
npm install xmlhttprequest

使用淘宝镜像源安装成功:

javascript 复制代码
https://registry.npmmirror.com/

package-lock.json:

2.2 安装xmlhttprequest后需要引入

上述直接定义方式为如下:

javascript 复制代码
new XMLHttpRequest()

安装后node执行依然报错提示:ReferenceError: XMLHttpRequest is not defined,是因为还需要引入使用。

使用node命令,那么需要使用CommonJS模块系统的require,引入如下:

javascript 复制代码
let request = require('xmlhttprequest').XMLHttpRequest;

重新执行node xx.js不再报错。

2.3 如何使用模块Module的方式引入呢?

因为Node生态包含两个不同的模块系统,ESM(ECMAScript模块)和 CommonJS,两个模块系统彼此不兼容。如果我们希望使用module引入的方式来执行(ECMAScript),而不是上面的CommonJS的require引入,修改如下:

javascript 复制代码
import * as request from "xmlhttprequest";

但是直接执行报错提示:SyntaxError: Cannot use import statement outside a module

解决方式是在执行的js文件所在目录下的package.json文件中,添加如下配置:

javascript 复制代码
"type":"module",

但是因为这里是跑的demo项目,没有package.json文件,这里我在开启终端的文件目录下生成package.json文件:

生成package.json的命令:

javascript 复制代码
npm init -y

或者npm init(需要多次回车确定以及输入yes)

生成 package-lock.json

javascript 复制代码
npm install --package-lock-only

在首次安装依赖包时会创建package-lock.json文件,这里我们使用npm init生成package.json文件即可:

在es6目录下的终端输入npm init后,生成package.json文件:

新增如下配置:

javascript 复制代码
"type":"module",

再次执行如下:

javascript 复制代码
import * as request from "xmlhttprequest";
const req = new request.XMLHttpRequest();

console.log(req)

执行无误:

相关推荐
竹林8182 分钟前
RainbowKit 快速集成多链钱包连接:从“连不上”到丝滑切换的踩坑实录
前端·javascript
aq553560024 分钟前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
报错小能手1 小时前
ios开发方向——swift错误处理:do/try/catch、Result、throws
开发语言·学习·ios·swift
嗜好ya1 小时前
解决 Vite 项目中 import.meta.env 变量为 undefined 的问题
前端·javascript·vue.js
心连欣1 小时前
JS算法入门:图解“冒泡排序”,彻底搞懂双重循环的奥义
前端·javascript
网域小星球1 小时前
C 语言从 0 入门(十七)|结构体指针 + 动态内存 + 文件综合实战
c语言·开发语言·文件操作·结构体指针·动态内存·综合项目
aq55356001 小时前
三大编程语言深度对比:C# vs 易语言 vs 汇编
开发语言·汇编·c#
独特的螺狮粉1 小时前
云隙一言:鸿蒙Flutter框架 实现的随机名言应用
开发语言·flutter·华为·架构·开源·harmonyos
光泽雨2 小时前
c# 文件编译的过程
开发语言·c#
赤水无泪2 小时前
09 C++ 11 新增的标准
开发语言