/**
* Created by wensonsmith on 2017/12/5.
*/
const path = require('path')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const ExtractTextPlugin = require('extract-text-webpack-plugin')
let isProd = process.env.NODE_ENV === 'production'
module.exports = {
entry: {
main: './main',
vendors: ['vue', 'vuex', 'vue-router', 'axios'],
},
output: {
path: path.join(__dirname, '../dist'),
publicPath: '/'
},
module: {
rules: [{
test: /\.vue$/,
loader: 'vue-loader',
options: {
loaders: {
sass: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
{ loader: 'sass-loader', options: { sourceMap: !isProd } }
],
fallback: 'vue-style-loader'
}),
css: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
],
fallback: 'vue-style-loader'
}),
less: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
{ loader: 'less-loader', options: { sourceMap: !isProd } }
],
fallback: 'vue-style-loader'
})
}
}
},
{
test: /\.js$/,
loader: 'babel-loader',
exclude: /node_modules/
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
],
fallback: 'style-loader'
})
},
{
test: /\.sass/,
use: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
{ loader: 'sass-loader', options: { sourceMap: !isProd } }
],
fallback: 'style-loader'
})
},
{
test: /\.less/,
use: ExtractTextPlugin.extract({
use: [
{ loader: 'css-loader', options: { minimize: isProd, sourceMap: !isProd } },
{ loader: 'postcss-loader', options: { sourceMap: !isProd } },
{ loader: 'less-loader', options: { sourceMap: !isProd } }
],
fallback: 'style-loader'
})
},
{
test: /\.(woff|eot|ttf)\??.*$/,
use: [{
loader: 'url-loader',
options: {
limit: 1024,
name: 'fonts/[name].[ext]'
}
}]
},
{
test: /\.(gif|jpg|png|svg)\??.*$/,
use: [{
loader: 'url-loader',
options: {
limit: 1024,
name: 'images/[name].[ext]'
}
}]
},
{
test: /\.(html|tpl)$/,
loader: 'html-loader'
}
]
},
resolve: {
extensions: ['.js', '.vue'],
alias: {
'vue': 'vue/dist/vue.esm.js',
'assets': path.resolve('src/assets') //能夠在文件中使用 ~assets 訪問
}
},
plugins: [
new webpack.optimize.CommonsChunkPlugin({
name: 'plugins',
filename: 'plugins.[hash:8].js',
chunks: ['main', 'plugins']
}),
new webpack.optimize.CommonsChunkPlugin({
name: 'vendors',
filename: 'vendors.[hash:8].js',
chunks: ['plugins']
}),
// new HtmlWebpackPlugin({
// filename: 'index.html',
// template: './index.html',
// inject: true,
// chunksSortMode: 'dependency'
// }),
new HtmlWebpackPlugin({
filename: '../../../../modules/tuition/views/tuition-order/index.php',
template: './index.html',
inject: true,
chunksSortMode: 'dependency'
}),
]
}