我发现了一些与此相关的 StackOverflow 问题,但没有一个匹配或解决我的问题。
我正在用 ES6 编写一个旨在用于浏览器和服务器的库。我发现了一些可以在服务器或浏览器上使用的 HTTP 请求库(popsicle,axios)。我已经在这两个地方成功地使用了这些库,但是在将它们导入我的源代码并使用输出的 webpacked 文件时遇到了一些问题。
我要导入axios
库的 ES6 源文件是
import axios from 'axios';
export default {
go: function() {
return axios.get('http://www.google.com');
}
};
我的 webpack 配置是
var webpack = require('webpack');
var UglifyJsPlugin = webpack.optimize.UglifyJsPlugin;
var WebpackNotifierPlugin = require('webpack-notifier');
var path = require('path');
var env = require('yargs').argv.mode;
var libraryName = 'library';
var source = '/src/test.js';
var plugins = [],
outputFile;
if (env === 'build') {
plugins.push(new UglifyJsPlugin({
minimize: true
}));
outputFile = libraryName + '.min.js';
} else {
outputFile = libraryName + '.js';
plugins.push(new WebpackNotifierPlugin())
}
var config = {
entry: __dirname + source,
devtool: 'source-map',
output: {
path: __dirname + '/lib',
filename: outputFile,
library: libraryName,
libraryTarget: 'umd',
umdNamedDefine: true
},
externals: {},
module: {
loaders: [{
test: /(\.jsx|\.js)$/,
loader: 'babel',
exclude: /(node_modules|bower_components)/
}, {
test: /(\.jsx|\.js)$/,
loader: "eslint-loader",
exclude: /node_modules/
}]
},
resolve: {
root: path.resolve('./src'),
extensions: ['', '.js']
},
plugins: plugins
};
module.exports = config;
如您所见,我将 libraryTarget 设置为umd
并将 umdNamedDefine 设置为true
而我.bablerc
的是
{
"presets": ["es2015"],
"plugins": ["add-module-exports", "babel-plugin-add-module-exports"]
}
我可以通过将我的库包含在script
标签中来在浏览器中使用它,但是在使用 node.js 导入时我无法使用它。我得到一个XMLHttpRequest is not defined
. axios 库表示它在浏览器上使用 XMLHttpRequest,在节点中运行时使用 http,但由于某种原因,它没有检测到它正在服务器上运行。我在一些 UML 库中遇到了这个问题,所以相信它不是特定的包。此外,由于我可以在节点 ES5 中使用这些库而无需运行 webpack 或 babel,因此我被认为是 webpack 的配置问题。
如何在 ES6 中导入这些 UMD 样式库并生成一个可以在服务器和浏览器上使用的带有 Webpack 和 Babel 的库?