// 一個(gè)常見的`webpack`配置文件
const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
module.exports = {
????????//加載器配置?
?????????//module.loaders 是最關(guān)鍵的一塊配置吐绵。它告知 webpack 每一種文件都需要使用什么加載器來處理
? ? ? ? entry: __dirname + "/app/main.js", //已多次提及的唯一入口文件
? ? ? ? output: {
? ? ? ? ? ? path: __dirname + "/build",? //path: 打包好的資源存放的位置
? ? ? ? ? ? filename: "bundle-[hash].js"? //filename: 打包后的文件名
? ? ? ? },
? ? ? ? devtool: 'none',
? ? ? ? devServer: {
? ? ? ? ? ? contentBase: "./public", //本地服務(wù)器所加載的頁面所在的目錄
? ? ? ? ? ? historyApiFallback: true, //不跳轉(zhuǎn)
? ? ? ? ? ? inline: true,
? ? ? ? ? ? hot: true
? ? ? ? },
? ? ? ? module: {
? ? ? ? ? ? rules: [{
? ? ? ? ? ? ? ? ? ? test: /(\.jsx|\.js)$/,? ? //用于匹配加載器支持的文件格式的正則表達(dá)式
? ? ? ? ? ? ? ? ? ? use: {
? ? ? ? ? ? ? ? ? ? ? ? loader: "babel-loader"? ?? //多個(gè)加載器通過"!"連接,加載器是從右向左開始使用的 //loader指定了要使用的加載器類型
? ? ? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? exclude: /node_modules/
? ? ? ? ? ? ? ? }, {
? ? ? ? ? ? ? ? ? ? test: /\.css$/,
? ? ? ? ? ? ? ? ? ? use: ExtractTextPlugin.extract({
? ? ? ? ? ? ? ? ? ? ? ? fallback: "style-loader",
? ? ? ? ? ? ? ? ? ? ? ? use: [{
? ? ? ? ? ? ? ? ? ? ? ? ? ? loader: "css-loader",
? ? ? ? ? ? ? ? ? ? ? ? ? ? options: {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? modules: true,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? localIdentName: '[name]__[local]--[hash:base64:5]'
? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? }, {
? ? ? ? ? ? ? ? ? ? ? ? ? ? loader: "postcss-loader"
? ? ? ? ? ? ? ? ? ? ? ? }],
? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? ]
? ? },
? ? plugins: [
? ? ? ? new webpack.BannerPlugin('版權(quán)所有,翻版必究'),
? ? ? ? new HtmlWebpackPlugin({
? ? ? ? ? ? template: __dirname + "/app/index.tmpl.html" //new 一個(gè)這個(gè)插件的實(shí)例河绽,并傳入相關(guān)的參數(shù)
? ? ? ? }),
? ? ? ? new webpack.optimize.OccurrenceOrderPlugin(),
? ? ? ? new webpack.optimize.UglifyJsPlugin(),
? ? ? ? new ExtractTextPlugin("style.css")
? ? ]
};