7

我有以下 webpack 配置:

const path = require('path');
const webpack = require('webpack');
const CleanWebpackPlugin = require('clean-webpack-plugin');

module.exports = {
    entry: {
        source1: './frontend/source1.js',
        source2: './frontend/source2.js'
    },
    output: {
        filename: '[name].bundle.js',
        path: path.resolve(__dirname, 'static/bundles')
    },
    plugins: [
        new CleanWebpackPlugin(['static/bundles'])
    ],
    module: {
        rules: [
            {
                test: /\.vue$/,
                loader: 'vue-loader', //  для .vue-файлов
                options: {
                    loaders: {
                    }
                    // other vue-loader options go here
                }
            },
            {
                test: /\.js$/,
                exclude: /node_modules/,
                loader: "babel-loader"
            }
        ]
    },
    resolve: {
        alias: {
            vue$: 'vue/dist/vue.esm.js'
        }
    }
};

当我运行 webpack 时,我希望它生成两个文件:source1.bundle.jssource2.bundle.js.

但它也会产生一个神秘的0.bundle.js并将其放在与其他文件相同的目录中。

在此处输入图像描述

然后当我打开浏览器时,我得到一个错误:

在此处输入图像描述

因为我的包是从一个单独的绝对/static/bundles/目录加载的,这0.bundle.js是试图从当前页面而不是/static/bundles/. 这个文件是什么,如何为它指定加载路径?

4

1 回答 1

0

我相信你会想要在 webpack 配置中添加一个 publicPath。就在您实际阅读它们的任何地方。 output: { filename: 'bundle.js', path: path.resolve(__dirname, 'public/dist'), publicPath: './dist/' },

于 2018-08-31T03:24:38.730 回答