2016-10-21 67 views
0

我一直在試用ES6/Angular 1.X & webpack。我克隆&做了一些次要的mods到這個回購:https://github.com/geniuscarrier/webpack-angular-es6ES6 Angular 1.X + Webpack生產版本很大(1.8 megs)

應用程序的偉大工程....但是當它的時間來生產,產生的bundle.js文件幾乎2兆。

我已經經歷了幾個SO帖子,並已實施了一些建議的策略,似乎沒有任何工作。

任何人有任何洞見,他們可以分享?我真的很感激。

這裏是我的package.json:

{ 
    "name": "Webpack-Angular", 
    "version": "1.0.0", 
    "description": "", 
    "main": "index.js", 
    "scripts": { 
     "test": "npm run lint && NODE_ENV=test ./node_modules/.bin/karma start", 
     "lint": "./node_modules/.bin/eslint app", 
     "dev": "./node_modules/.bin/webpack-dev-server --content-base app", 
     "build": "NODE_ENV=production webpack -p && cp app/index.html build/index.html && cp -r app/images build/images" 
     }, 
     "author": "", 
     "license": "ISC", 
     "devDependencies": { 
      "angular": "^1.5.5", 
      "angular-mocks": "^1.5.5", 
      "angular-sanitize": "^1.5.5", 
      "angular-ui-router": "^0.2.18", 
      "autoprefixer-loader": "^3.2.0", 
      "babel-core": "^6.7.7", 
      "babel-loader": "^6.2.4", 
      "babel-preset-angular": "^6.0.15", 
      "babel-preset-es2015": "^6.6.0", 
      "bootstrap": "^3.3.6", 
      "chai": "^3.5.0", 
      "css-loader": "^0.23.1", 
      "eslint": "^2.2.0", 
      "file-loader": "^0.8.5", 
      "font-awesome": "^4.5.0", 
      "jquery": "^2.2.3", 
      "karma": "^0.13.22", 
      "karma-chai": "^0.1.0", 
      "karma-chrome-launcher": "^0.2.3", 
      "karma-mocha": "^0.2.2", 
      "karma-webpack": "^1.7.0", 
      "mocha": "^2.4.5", 
      "ng-annotate-loader": "^0.1.0", 
      "ng-resource": "^1.3.2", 
      "node-sass": "^3.6.0", 
      "raw-loader": "^0.5.1", 
      "sass-loader": "^3.2.0", 
      "style-loader": "^0.13.1", 
      "toastr": "^2.1.2", 
      "url-loader": "^0.5.7", 
      "webpack": "^1.13.0", 
      "webpack-dev-server": "^1.14.1" 
     } 
    } 

這裏是的WebPack配置:

var DefinePlugin = require('webpack').DefinePlugin; 
var ProvidePlugin = require('webpack').ProvidePlugin; 
var optimize = require('webpack').optimize; 

var definePlugins = new DefinePlugin({ 
    TEST: process.env.NODE_ENV === 'test', 
    PRODUCTION: process.env.NODE_ENV === 'production' 
}); 
var providePlugins = new ProvidePlugin({ 
    $: 'jquery', 
    jQuery: 'jquery', 
    'window.jQuery': 'jquery', 
    'windows.jQuery': 'jquery', 
}); 

var config = { 
    context: __dirname + '/app', 
    entry: './index.js', 
    output: { 
     path: __dirname + '/app', 
     filename: 'bundle.js' 
    }, 
    devtool: 'source-map', 
    module: { 
     loaders: [{ 
      test: /\.js$/, 
      exclude: /(node_modules)/, 
      loader: 'ng-annotate!babel' 
     }, { 
     test: /\.s?css$/, 
     exclude: /(node_modules)/, 
     loaders: ['style', 'css?sourceMap', 'autoprefixer', 'sass?sourceMap'] 
    }, { 
     test: /\.html$/, 
     loader: 'raw' 
    }, { 
     test: /\.(jpe?g|png|gif)$/, 
     exclude: /(node_modules)/, 
     loader: 'url?limit=10000' 
    }, { 
     test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/, 
     loader: 'url?limit=10000&minetype=application/font-woff' 
    }, { 
     test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/, 
     loader: 'url' 
    }] 
}, 
plugins: [ 
    definePlugins, 
    providePlugins 
], 
resolve: { 
    extensions: ['', '.js', '.css'] 
} 
}; 

if (process.env.NODE_ENV === 'production') { 
    config.output.path = __dirname + '/build'; 
    config.plugins.push(new optimize.UglifyJsPlugin()); 
} 

module.exports = config; 

謝謝。

回答

0

在webpack 2上,您可以更改配置上的resolve.extensions。默認情況下,模塊分辨率如下所示:`[「.js」,「.json」],您可以更改爲:[「.min.js」,「.js」,「.json]」,webpack將以min首先文件;減少你的包的大小。