首页 > 代码库 > WEBPACK简介

WEBPACK简介

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 })
            } ]
        }
    };

  

 

  

  

  

  

WEBPACK简介