問題:開發過程當中不免有跨域的問題。css
解決:webpack代理的配置html
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const webpack = require('webpack');
module.exports = {
entry: './src/app.jsx',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'js/app.js',
publicPath: "/dist/"
},
resolve: {
alias : {
page : path.resolve(__dirname, 'src/page'),
component : path.resolve(__dirname, 'src/component'),
util : path.resolve(__dirname, 'src/util'),
service : path.resolve(__dirname, 'src/service'),
}
},
module: {
rules: [
//jsx
{
test: /\.jsx$/,
exclude: /(node_modules)/,
use: {
loader: 'babel-loader',
options: {
presets: ['env','react']//根據環境打包(瀏覽器,node)
}
}
},
//css
{
test: /\.css$/,
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: "css-loader"
})
},
//sass
{
test: /\.scss$/,
use: ExtractTextPlugin.extract({
fallback: 'style-loader',
use: ['css-loader', 'sass-loader']
})
},
//圖片的配置
{
test: /\.(png|jpg|gif)$/i,
use: [
{
loader: 'url-loader',
options: {
limit: 8192,
name:'resource/[name].[ext]'
}
}
]
},
//字體的配置
{
test: /\.(otf|eot|svg|ttf|woff|woff2)$/i,
use: [
{
loader: 'url-loader',
options: {
limit: 8192,
name:'resource/[name].[ext]'
}
}
]
}
]
},
plugins: [
//處理css文件
new HtmlWebpackPlugin({
template:'./src/index.html',
favicon:'./favicon.ico'
}),
//獨立css
new ExtractTextPlugin("css/[name].css"),//參數爲生成css的位置
//提取公共模塊
new webpack.optimize.CommonsChunkPlugin({//webpack自帶插件,不用安裝
name:'common',
filename:'js/base.js'
})
],
devServer: {
// contentBase: path.join(__dirname, 'dist'),
port: 9999,
historyApiFallback:{
index : '/dist/index.html'//404
},
proxy : {
'/manage' : {
target : 'http://admintest.happymmall.com',
changeOrigin : true
}
}
}
};