Rollup包axios,无法使用

Bla*_*ole 4 rollup node.js axios

项目中使用的是axios,然后使用rollup进行打包。

在浏览器端,这是正常的。但是在nodejs端就报错。

错误信息:

node test\test.js
error
ReferenceError: XMLHttpRequest is not defined
    at dispatchXhrRequest (D:\Project\NodeJs\rollup-axios-error-demo\dist\demo.js:684:21)
    at new Promise (<anonymous>)
    at xhrAdapter (D:\Project\NodeJs\rollup-axios-error-demo\dist\demo.js:676:12)
    at dispatchRequest (D:\Project\NodeJs\rollup-axios-error-demo\dist\demo.js:1082:12)
    at process._tickCallback (internal/process/next_tick.js:68:7)
    at Function.Module.runMain (internal/modules/cjs/loader.js:745:11)
    at startup (internal/bootstrap/node.js:266:19)
    at bootstrapNodeJSCore (internal/bootstrap/node.js:596:3)
Run Code Online (Sandbox Code Playgroud)

我创建了一个演示可供您查看:rollup-axios-error-demo

axios源码区分运行环境的代码为:

function getDefaultAdapter() {
  var adapter;
  if (typeof XMLHttpRequest !== 'undefined') {
    // For browsers use XHR adapter
    adapter = require('./adapters/xhr');
  } else if (typeof process !== 'undefined') {
    // For node use HTTP adapter
    adapter = require('./adapters/http');
  }
  return adapter;
}
Run Code Online (Sandbox Code Playgroud)

但打包后就变成了:

function getDefaultAdapter() {
  var adapter;
  if (typeof XMLHttpRequest !== 'undefined') {
    // For browsers use XHR adapter
    adapter = xhr;
  } else if (typeof process !== 'undefined') {
    // For node use HTTP adapter
    adapter = xhr;
  }
  return adapter;
}
Run Code Online (Sandbox Code Playgroud)

导致 XMLHttpRequest 在 nodejs 端实例化

小智 6

如果有人偶然发现这一点,我也遇到了同样的问题,并通过切换import axios from 'axios'const axios = require("axios")使用 axios 的任何文件来解决它。