Webpack 是一个强力的模块打包器。 所谓 包 (bundle) 就是一个 JavaScript 文件,它把一堆 资源 (assets) 合并在一起,以便它们可以在同一个文件请求中发回给客户端。 包中可以包含 JavaScript 、 CSS 样式、 HTML 以及很多其它类型的文件。
1、安装
//全局安装 npm install -g webpack //安装到你的项目目录 npm install --save-dev webpack
我们通过一个 JavaScript 配置文件 webpack.config.js
来决定 Webpack 做什么以及如何做。
2、入口与输出
entry: { app: 'src/app.ts' }
Webpack 探查那个文件,并且递归遍历它的 import
依赖。
output: { filename: 'app.js' }
这个 app.js
输出包是个单一的 JavaScript 文件,它包含程序的源码及其所有依赖。 后面我们将在 index.html
中用 <script>
标签来加载它。
3、多重包
entry: { app: 'src/app.ts', vendor: 'src/vendor.ts' }, output: { filename: '[name].js' }
在输出文件名中出现的 [name]
是一个 Webpack 的 占位符 ,它将被替换为入口点的名字,分别是 app
和 vendor
4、加载器
loaders: [ { test: /.ts$/ loaders: 'ts' }, { test: /.css$/ loaders: 'style!css' } ]
当 Webpack 遇到像这样的 import
语句时……
import { AppComponent } from './app.component.ts'; import 'uiframework/dist/uiframework.css';
它会使用 test
后面的正则表达式进行模式匹配。
5、插件
plugins: [ new webpack.optimize.UglifyJsPlugin() ]
我们已经了解webpack的基本配置了,那么我们开始
6、完整配置
module.exports = { entry: './index.js', devtool: 'source-map', output: { filename: '[name].js' }, resolve: { alias:{ jquery: 'src/lib/jquery.js', } }, plugins: [ new webpack.ProvidePlugin({ $: 'jquery', _: 'underscore', React: 'react' }), new WebpackNotifierPlugin() ], module: { loaders: [{ test: /.js[x]?$/, exclude: /node_modules/, loader: 'babel-loader' }, { test: /.less$/, loaders:['style-loader', 'css-loader','less-loader'] }, { test: /.(png|jpg|gif|woff|woff2|ttf|eot|svg|swf)$/, loader: "file-loader?name=[name]_[sha512:hash:base64:7].[ext]" }, { test: /.html/, loader: "html-loader?" + JSON.stringify({minimize: false }) } ] } };