-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack-test.js
99 lines (79 loc) · 2.63 KB
/
webpack-test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
"use strict";
const fs = require("fs");
const path = require("path");
const webpack = require("webpack");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const CopyWebpackPlugin = require("copy-webpack-plugin");
const CleanWebpackPlugin = require("clean-webpack-plugin");
/*
const extractStyle_Vendor = new ExtractTextPlugin(AbsolutePathPrefix + "static/css/vendor.css");
const extractStyle_App = new ExtractTextPlugin(AbsolutePathPrefix + "static/css/[name].css");
*/
const extractStyle_Vendor = new ExtractTextPlugin("static/css/[name]-vendor.css");
const extractStyle_App = new ExtractTextPlugin("static/css/[name].css");
/**********************************************************************************************************************/
module.exports = {
devtool: "source-map",
devServer: {
colors: true,
historyApiFallback: true,
inline: true,
},
resolve: {
extensions: ["", ".js", ".ts", ".json", ".html", ".less"],
alias: {
/**
* Own package alias
*/
"src": path.join(__dirname, "src"),
}
},
entry: {
},
output: {
path: path.resolve(__dirname, "dev"),
filename: "static/js/[name].js"
},
module: {
loaders: [
{
test: /\.html$/,
loader: "html?attrs=img:src link:href script:src"
},
// Process Vendor JS files.
{
test: /vendor.*\.js$/,
//test: /jquery\.js$/,
loader: "file?name=static/vendor/js/[name]-[hash:5].[ext]"
//loader: "file!extract!imports?jQuery=jquery,$=jquery,this=>window!raw"
},
// Process Vendor JS files.
{
//test: /\/lib\/vendor.*\.js/,
test: /bootstrap\.js$/,
loader: "file?name=static/vendor/js/[name].[ext]"
//loader: "file!script!imports?this=window"
}
]
},
plugins: [
// This helps ensure the builds are consistent if source hasn't changed:
new webpack.optimize.OccurrenceOrderPlugin(),
/**
* 使用html模板文件进行创建
*/
new HtmlWebpackPlugin({
filename: "index.html",
template: "src/test/index.html",
chunks: ["index"]
}),
new CleanWebpackPlugin(["dev"], {
root: __dirname,
verbose: false,
}),
],
postcss: function () {
return [require("autoprefixer")];
},
};