Как ускорить мой .NET core + Vuejs с веб-приложением webpack? - PullRequest
0 голосов
/ 28 октября 2019

Я создаю веб-приложение в Visual studio и использую Vuejs для внешнего интерфейса и .NET для внутреннего интерфейса. Я использовал веб-пакет в качестве JS-упаковщика. Ниже приведен мой файл webpack.config.cs

var path = require('path')
var webpack = require('webpack')
const bundleOutputDir = './wwwroot/dist';

module.exports = {
    context: __dirname,
    entry: { main: './App/index.js' },
    module: {
        rules: [
            {
                test: /\.css$/,
                use: [
                    'vue-style-loader',
                    'css-loader'
                ],
            },
            {
                test: /\.vue$/,
                loader: 'vue-loader',
                options: {
                    loaders: {
                        'scss': [
                            'vue-style-loader',
                            'css-loader',
                            'sass-loader'
                        ],
                        'sass': [
                            'vue-style-loader',
                            'css-loader',
                            'sass-loader?indentedSyntax'
                        ]
                    }
                }
            },
            {
                test: /\.js$/,
                loader: 'babel-loader',
                exclude: /node_modules/
            },
            {
                test: /\.(png|jpg|gif|svg|woff|woff2|eot|ttf)$/,
                loader: 'url-loader?limit=100000',
                options: {
                    name: '[name].[ext]?[hash]'
                }
            }
        ]
    },
    plugins: [
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: JSON.stringify('production')
            }
        }),
        new webpack.ProvidePlugin({
            Vue: ['vue/dist/vue.min.js', 'default'],
            jQuery: 'jquery',
            'window.jQuery': 'jquery',
            $: 'jquery',
            moment: 'moment',
        })
    ],
    resolve: {
        alias: {
            'vue$': 'vue/dist/vue.min.js',
            'jquery': 'jquery/src/jquery.js'
        },
        extensions: ['*', '.js', '.vue', '.json']
    },
    devServer: {
        historyApiFallback: true,
        noInfo: true,
        overlay: true
    },
    performance: {
        hints: false
    }, output: {
        path: path.join(__dirname, bundleOutputDir),
        filename: '[name].js',
        publicPath: 'dist/'
    },
    devtool: '#eval-source-map'
}

if (process.env.NODE_ENV === 'production') {
    module.exports.devtool = '#source-map'
    module.exports.plugins = (module.exports.plugins || []).concat([
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: '"production"'
            }
        }),
        new webpack.optimize.UglifyJsPlugin({
            sourceMap: true,
            compress: {
                warnings: false
            }
        }),
        new webpack.LoaderOptionsPlugin({
            minimize: true
        })
    ])
}

Папка модулей узла содержит vue / dist, в которой много файлов, а именно: vue.common.js, vue.min.js и другие. Вывод файла происходит в папке dist, расположенной в wwwroot.

Проблема, с которой я сталкиваюсь, заключается в том, что приложение загружается много времени. Как ускорить процесс? Я понимаю, что это связано с изменением конфигурации веб-пакета, но я не могу понять это.

...