gpt4 book ai didi

用于生产部署的 Angular 2 + Webpack

转载 作者:太空狗 更新时间:2023-10-29 18:33:41 26 4
gpt4 key购买 nike

我想在我的生产部署中使用 webpack 缩小我所有的 js 和 CSS & 当我开始在开发模式下工作时它应该得到美化,我是 webpack 的新手 & 不确定我是如何做到这一点的,下面是我的 webpack 配置,如何修改它以在开发和生产环境中单独工作?

var webpack = require('webpack');
var path = require('path');

// Webpack Config
var webpackConfig = {
entry: {
'polyfills': './src/polyfills.browser.ts',
'vendor': './src/vendor.browser.ts',
'main': './src/main.browser.ts',
},

output: {
path: './dist',
},

plugins: [
new webpack.optimize.OccurenceOrderPlugin(true),
new webpack.optimize.CommonsChunkPlugin({ name: ['main', 'vendor', 'polyfills'], minChunks: Infinity }),
],

module: {
loaders: [
// .ts files for TypeScript
{ test: /\.ts$/, loaders: ['awesome-typescript-loader', 'angular2-template-loader'] },
{ test: /\.css$/, loaders: ['to-string-loader', 'css-loader'] },
{ test: /\.html$/, loader: 'raw-loader' },
{ test: /\.json$/, loader: 'json-loader' },
]
}

};


// Our Webpack Defaults
var defaultConfig = {
devtool: 'cheap-module-source-map',
cache: true,
debug: true,
output: {
filename: '[name].bundle.js',
sourceMapFilename: '[name].map',
chunkFilename: '[id].chunk.js'
},

module: {
preLoaders: [
{
test: /\.js$/,
loader: 'source-map-loader',
exclude: [
// these packages have problems with their sourcemaps
path.join(__dirname, 'node_modules', 'rxjs'),
path.join(__dirname, 'node_modules', '@angular2-material'),
path.join(__dirname, 'node_modules', '@angular'),
]
}
],
noParse: [
path.join(__dirname, 'node_modules', 'zone.js', 'dist'),
path.join(__dirname, 'node_modules', 'angular2', 'bundles')
]
},

resolve: {
root: [ path.join(__dirname, 'src') ],
extensions: ['', '.ts', '.js', '.json']
},

devServer: {
historyApiFallback: true,
watchOptions: { aggregateTimeout: 300, poll: 1000 }
},

node: {
global: 1,
crypto: 'empty',
module: 0,
Buffer: 0,
clearImmediate: 0,
setImmediate: 0
},
}

var webpackMerge = require('webpack-merge');
module.exports = webpackMerge(defaultConfig, webpackConfig);

所以当我启用 anggular 2 enableProduction 时,webpack 也应该调用生产代码并缩小 JS 和 CSS

最佳答案

您可以创建一个 webpack.config.production.js,然后在主 webpack.config.js 中您可以像这样导入生产配置:

var environment = process.env.NODE_ENV ? process.env.NODE_ENV:“本地”;var envSpecificConfig = require('./webpack.config.' + environment);

其中环境由 gulp 或您的构建服务器或其他方式设置为环境变量。

所以原则上所有常见的配置都将进入 webpack.config.js 而生产的东西将进入 webpack.config.production.js。

示例配置在这里(首先是 webpack.config.js):

var path = require('path');
var webpack = require('webpack');
var merge = require('extendify')({ isDeep: true, arrays: 'concat' });
var environment = process.env.NODE_ENV ? process.env.NODE_ENV : "local";
var envSpecificConfig = require('./webpack.config.' + environment);

module.exports = merge({

...all your standard stuff you already have here

}, envSpecificConfig);

然后在webpack.config.production.js

var webpack = require('webpack');
var path = require( 'path' );

module.exports = {
plugins: [
new webpack.optimize.UglifyJsPlugin({
compress: { warnings: false },
minimize: true,
mangle: false // Due to https://github.com/angular/angular/issues/6678
})
]
};

这样你就可以拥有任意数量的环境特定配置,你只需设置环境变量以匹配配置文件名。

关于用于生产部署的 Angular 2 + Webpack,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38580642/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com