加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
webpack.config.js 3.75 KB
一键复制 编辑 原始数据 按行查看 历史
宋耀伦 提交于 2020-07-08 19:56 . 完善后台订单模块
/*
* @Author: Rosen
* @Date: 2016-11-20 13:19:28
* @Last Modified by: 96173
* @Last Modified time: 2018-01-11 12:08:27
* 知识点:css单独打包、全局jquery引用、各种loader
*/
var webpack = require('webpack');
var path = require('path');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin');
// 环境变量, dev, (test), online
var WEBPACK_ENV = process.env.WEBPACK_ENV || 'dev';
// webpack config
var config = {
entry:{
'app' : ['./src/index.jsx']
},
externals:{
'$' :'window.jQuery',
'jquery' :'window.jQuery'
},
// path && publickPath
output: {
path : __dirname + '/dist/',
publicPath : '/dist/',
filename : 'js/[name].js'
},
resolve: {
alias: {
node_modules : path.join(__dirname, '/node_modules'),
lib : path.join(__dirname, '/src/lib'),
util : path.join(__dirname, '/src/util'),
component : path.join(__dirname, '/src/component'),
service : path.join(__dirname, '/src/service'),
page : path.join(__dirname, '/src/page'),
}
},
module: {
// noParse: [],
loaders: [
{test: /\.css$/, loader: ExtractTextPlugin.extract({
use: 'css-loader',
fallback : 'style-loader'
})},
{test: /\.scss$/, loader: ExtractTextPlugin.extract({
use: 'css-loader!sass-loader',
fallback : 'style-loader'
})},
{test: /\.(gif|jpg|png|woff|svg|eot|ttf)\??.*$/, loader: 'url-loader?limit=20000&name=resource/[name].[ext]'},
{test: /\.(string)$/, loader: 'html-loader' },
{
test: /\.js?$/,
exclude: /(node_modules)/,
loader: 'babel-loader',
query: {
presets: ['es2015']
}
},
{
test: /\.jsx?$/,
exclude: /(node_modules)/,
loader: 'babel-loader',
query: {
presets: ['react', 'es2015']
}
},
]
},
plugins: [
// 提出公共部分
new webpack.optimize.CommonsChunkPlugin({
name : 'vendors',
filename : 'js/base.js'
}),
// 单独处理css
new ExtractTextPlugin('css/[name].css'),
// html 加载
new HtmlWebpackPlugin({
filename : 'view/index.html',
title : 'SMall 后台管理系统',
template : './src/index.html',
favicon : './favicon.ico',
inject : true,
hash : true,
chunks : ['vendors', 'app'],
chunksSortMode : 'dependency',
minify : {
removeComments: true,
collapseWhitespace: false
}
}),
],
devServer: {
port: 8088,
historyApiFallback: {
index: '/dist/index.html'
},
proxy : {
'/manage' : {
target: 'http://101.200.194.48:8081',
// target: 'http://127.0.0.1:8081',
changeOrigin : true
},
'/user/logout.do' : {
target: 'http://101.200.194.48:8081',
changeOrigin : true
}
}
}
};
// 开发环境下,使用devServer热加载
if(WEBPACK_ENV === 'dev'){
config.entry.app.push('webpack-dev-server/client?http://localhost:8086');
}
module.exports = config;
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化