手寫一個簡單的webpack的配置

const path = require("path");
const htmlWebpackPlugin = require("html-webpack-plugin");

//定義入庫文件和出口文件路徑
const PATH = {
    app:path.join(__dirname,"./src/js/main.js"),
    build:path.join(__dirname,"./dist")
}
///https://mapi.eyee.com/api/product/guessWhatYouLike
//如下是webpack的配置項
module.exports = {
    entry:{
        app:PATH.app,
    },
    output:{
        filename:"[name].js",
        path:PATH.build
    },
    module:{
        //loader的配置項
        rules:[
            {   
                //匹配.js文件
                test:/\.js$/,
                use:{
                    //遇到js文件用babell-loader處理
                    loader:"babel-loader",
                    options:{
                        //將ES6的代碼轉成ES5   遇到jsx語法的解析
                        presets:["@babel/env","@babel/react"]
                    }
                }
            },
            {
                test:/\.(css|scss)$/,
                use:["style-loader","css-loader","sass-loader"]
            },
            {
          test: require.resolve('zepto'),
          loader: 'exports-loader?window.Zepto!script-loader'
            }

        ]
    },
    //插件
    plugins:[
        //html模板
        new htmlWebpackPlugin({
            filename:"index.html",
            template:"./index.html",
            title:"鬥牛",
            chunks:["app"]
        })
        
    ],
    devServer:{
        //跨域配置
        proxy:{
            "/api":{
                target:"https://mapi.eyee.com",//目標地址
                changeOrigin:true,
                pathRewrite:{
                    "^/api":""
                }
            }
        }
    }
}
相關文章
相關標籤/搜索