/** * *@2018-10-08 * *@author trsoliu ?* *@describe vue-cli 3.x配置文件 */const path = require(‘path‘);const vConsolePlugin = require(‘vconsole-webpack-plugin‘); // 引入 移动端模拟开发者工具 插件 (另:https://github.com/liriliri/eruda)const CompressionPlugin = require(‘compression-webpack-plugin‘); //Gzipconst 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.mdchainWebpack: 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‘//} 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%8FconfigureWebpack: 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 modulesmodules: 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-loaderpluginOptions: {‘style-resources-loader‘: {//https://github.com/yenshih/style-resources-loaderpreProcessor: ‘scss‘,//声明类型‘patterns‘: [ ???????????????????????????????//path.resolve(__dirname, ‘./src/assets/scss/_common.scss‘), ], ???????????????????????//injector: ‘append‘}}};
vue.config.js
原文地址:https://www.cnblogs.com/alantao/p/10281853.html