Установите output.libraryTarget
как umd
в вашем webpack.config.js .По умолчанию libraryTarget
установлено var
.Возвращаемое значение присваивается переменной, его нельзя использовать внутри модуля
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
library: 'VueTopDown',
libraryTarget: 'umd',
umdNamedDefine: true
}
Несколько целей Хотя веб-пакет не поддерживает передачу нескольких строк в свойство цели, вы можете создатьИзоморфная библиотека путем объединения двух отдельных конфигураций: Несколько целей
const path = require('path');
const serverConfig = {
target: 'node',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'lib.node.js'
}
//…
};
const clientConfig = {
target: 'web', // <=== can be omitted as default is 'web'
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'lib.js'
}
//…
};
module.exports = [ serverConfig, clientConfig ];
Изменено webpack.config.js
для вашей справки
const path = require('path');
const webpack = require('webpack');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const serverConfig = {
mode: 'production',
target: 'node',
entry: {
'vue-top-down': './src/index.js',
'vue-top-down.min': './src/index.js'
},
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
library: 'VueTopDown',
libraryTarget: 'umd'
},
module: {
rules: [{
test: /\.js$/,
loader: 'babel-loader',
query: {
presets: ['env']
}
}]
},
stats: {
colors: true
},
devtool: 'source-map',
optimization: {
minimizer: [
new UglifyJsPlugin({
test: /\.min\.js$/
})
]
},
plugins: [
new CleanWebpackPlugin([
path.resolve(__dirname, 'dist')
]),
]
};
const clientConfig = {
mode: 'production',
target: 'web',
entry: {
'vue-top-down': './src/index.js',
'vue-top-down.min': './src/index.js'
},
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].web.js',
library: 'VueTopDown'
},
module: {
rules: [{
test: /\.js$/,
loader: 'babel-loader',
query: {
presets: ['env']
}
}]
},
stats: {
colors: true
},
devtool: 'source-map',
optimization: {
minimizer: [
new UglifyJsPlugin({
test: /\.min\.js$/
})
]
},
plugins: [
new CleanWebpackPlugin([
path.resolve(__dirname, 'dist')
]),
]
};
module.exports = [serverConfig, clientConfig];