const path = require('path'); const vConsolePlugin = require('vconsole-webpack-plugin'); // 引入 移動端模擬開發者工具 插件 (另:https://github.com/liriliri/eruda) const CompressionPlugin = require('compression-webpack-plugin'); //Gzip const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; //Webpack包文件分析器 const baseUrl = process.env.NODE_ENV === "production" ? "/static/" : "/"; //font scss資源路徑 不一樣環境切換控制 module.exports = { //基本路徑 baseUrl: './', //輸出文件目錄 outputDir: 'mcdonalds', // eslint-loader 是否在保存的時候檢查 lintOnSave: true, //放置生成的靜態資源 (js、css、img、fonts) 的 (相對於 outputDir 的) 目錄。 assetsDir: 'static', //以多頁模式構建應用程序。 pages: undefined, //是否使用包含運行時編譯器的 Vue 構建版本 runtimeCompiler: false, //是否爲 Babel 或 TypeScript 使用 thread-loader。該選項在系統的 CPU 有多於一個內核時自動啓用,僅做用於生產構建,在適當的時候開啓幾個子進程去併發的執行壓縮 parallel: require('os').cpus().length > 1, //生產環境是否生成 sourceMap 文件,通常狀況不建議打開 productionSourceMap: false, // webpack配置 //對內部的 webpack 配置進行更細粒度的修改 https://github.com/neutrinojs/webpack-chain see https://github.com/vuejs/vue-cli/blob/dev/docs/webpack.md chainWebpack: config => { /** * 刪除懶加載模塊的prefetch,下降帶寬壓力 * https://cli.vuejs.org/zh/guide/html-and-static-assets.html#prefetch * 並且預渲染時生成的prefetch標籤是modern版本的,低版本瀏覽器是不須要的 */ //config.plugins.delete('prefetch'); if(process.env.NODE_ENV === 'production') { // 爲生產環境修改配置...process.env.NODE_ENV !== 'development' // 如生產環境不壓縮js config.optimization.minimize(false) } else {// 爲開發環境修改配置... } }, //調整 webpack 配置 https://cli.vuejs.org/zh/guide/webpack.html#%E7%AE%80%E5%8D%95%E7%9A%84%E9%85%8D%E7%BD%AE%E6%96%B9%E5%BC%8F configureWebpack: config => { //生產and測試環境 let pluginsPro = [ new CompressionPlugin({ //文件開啓Gzip,也能夠經過服務端(如:nginx)(https://github.com/webpack-contrib/compression-webpack-plugin) filename: '[path].gz[query]', algorithm: 'gzip', test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$', ), threshold: 8192, minRatio: 0.8, }), // Webpack包文件分析器(https://github.com/webpack-contrib/webpack-bundle-analyzer) new BundleAnalyzerPlugin(), ]; //開發環境 let pluginsDev = [ //移動端模擬開發者工具(https://github.com/diamont1001/vconsole-webpack-plugin https://github.com/Tencent/vConsole) new vConsolePlugin({ filter: [], // 須要過濾的入口文件 enable: true // 發佈代碼前記得改回 false }), ]; if(process.env.NODE_ENV === 'production') { // 爲生產環境修改配置...process.env.NODE_ENV !== 'development' config.plugins = [...config.plugins, ...pluginsPro]; } else { // 爲開發環境修改配置... config.plugins = [...config.plugins, ...pluginsDev]; } }, css: { // 啓用 CSS modules modules: false, // 是否使用css分離插件 extract: true, // 開啓 CSS source maps,通常不建議開啓 sourceMap: false, // css預設器配置項 loaderOptions: { sass: { //設置css中引用文件的路徑,引入通用使用的scss文件(如包含的@mixin) data: ` $baseUrl: "/"; @import '@/assets/scss/_common.scss'; ` //data: ` //$baseUrl: "/"; //` } } }, // webpack-dev-server 相關配置 https://webpack.js.org/configuration/dev-server/ devServer: { // host: 'localhost', host: "0.0.0.0", port: 8000, // 端口號 https: false, // https:{type:Boolean} open: true, //配置自動啓動瀏覽器 http://172.16.1.12:7071/rest/mcdPhoneBar/ hotOnly: true, // 熱更新 // proxy: 'http://localhost:8000' // 配置跨域處理,只有一個代理 proxy: { //配置自動啓動瀏覽器 "/rest/*": { target: "http://172.16.1.12:7071", changeOrigin: true, // ws: true,//websocket支持 secure: false }, "/pbsevice/*": { target: "http://172.16.1.12:2018", changeOrigin: true, //ws: true,//websocket支持 secure: false }, } }, // 第三方插件配置 https://www.npmjs.com/package/vue-cli-plugin-style-resources-loader pluginOptions: { 'style-resources-loader': {//https://github.com/yenshih/style-resources-loader preProcessor: 'scss',//聲明類型 'patterns': [ //path.resolve(__dirname, './src/assets/scss/_common.scss'), ], //injector: 'append' } } };