zoukankan      html  css  js  c++  java
  • vue.config.js

    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'
    		}
    	}
    };
      
    

      

  • 相关阅读:
    P1099 [NOIP2007 提高组] 树网的核
    UVA 数学题选做
    Codeforces 729 Div.2
    P1600 [NOIP2016 提高组] 天天爱跑步
    CF1106F Lunar New Year and a Recursive Sequence
    P6091 【模板】原根
    P4774 [NOI2018] 屠龙勇士
    P1106 删数问题
    P1209 [USACO1.3]修理牛棚 Barn Repair
    网络(network)
  • 原文地址:https://www.cnblogs.com/alantao/p/10281853.html
Copyright © 2011-2022 走看看