vue项目打包部署初次访问慢问题

vue项目打包部署初次访问慢问题

#####打包部署访问

package.json中打包脚本部分

"scripts": {

"dev": "vue-cli-service serve",

"staging": "vue-cli-service serve --mode staging",

"production": "vue-cli-service serve --mode production",

"build:stage": "vue-cli-service build --mode staging",

"build:prod": "vue-cli-service build --mode production",

"preview": "node build/index.js --preview",

"lint": "eslint --ext .js,.vue src"

},

npm run build:stage

打包后,dist文件大概有20MB左右,首次访问单文件就有几兆

解决方案
复制代码
打包后,dist文件20多兆 
"compression-webpack-plugin": "^1.1.11",
npm install
vue.config.js配置
// 导入compression-webpack-plugin
const CompressionWebpackPlugin = require('compression-webpack-plugin')
// 定义压缩文件类型
const productionGzipExtensions = ['js', 'css']

configureWebpack: config => {
	config.name = name
	config.resolve.alias['@'] = resolve('src')
	config.performance = {
	  hints: 'warning',
	  //入口起点的最大体积 整数类型(以字节为单位)
	  maxEntrypointSize: 50000000,
	  //生成文件的最大体积 整数类型(以字节为单位 300k)
	  maxAssetSize: 30000000,
	  //只给出 js 文件的性能提示
	  assetFilter: function(assetFilename) {
		return assetFilename.endsWith('.js')
	  }
	}
	if (process.env.NODE_ENV !== 'development') {
	  // 生产环境
	  // 编译时删除console.log
	  config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true
	  //  配置productionGzip-高级的方式
	  // 配置参数详解
	  // asset: 目标资源名称。 [file] 会被替换成原始资源。[path] 会被替换成原始资源的路径, [query] 会被替换成查询字符串。默认值是 "[path].gz[query]"。
	  // algorithm: 可以是 function(buf, callback) 或者字符串。对于字符串来说依照 zlib 的算法(或者 zopfli 的算法)。默认值是 "gzip"。
	  // test: 所有匹配该正则的资源都会被处理。默认值是全部资源。
	  // threshold: 只有大小大于该值的资源会被处理。单位是 bytes。默认值是 0。
	  // minRatio: 只有压缩率小于这个值的资源才会被处理。默认值是 0.8。
	  config.plugins.push(
		new CompressionWebpackPlugin({
		  filename: '[path].gz[query]',
		  algorithm: 'gzip',
		  test: new RegExp('\\.(' + productionGzipExtensions.join('|') + ')$'),
		  threshold: 10240,
		  minRatio: 0.8,
		  // 是否删除原文件 
		  deleteOriginalAssets: true,
		})
	  )
	} else {
	  // 开发环境
	}
  },

#####nginx配置

开启gzip

gzip on;

复制代码
# 启用gzip压缩的最小文件,小于设置值的文件将不会压缩
gzip_min_length 1k;

# 设置压缩所需要的缓冲区大小
gzip_buffers 16 64k;

# 设置gzip压缩针对的HTTP协议版本
gzip_http_version 1.1;

# gzip 压缩级别,1-9,数字越大压缩的越好,也越占用CPU时间
gzip_comp_level 9;

gzip_types text/plain application/x-javascript application/javascript text/javascript text/css application/xml application/x-httpd-php image/jpeg image/gif image/png;

# 是否在http header中添加Vary: Accept-Encoding,建议开启
gzip_vary on;

# 禁用IE6 gzip
gzip_disable "MSIE [1-6]\.";
相关推荐
我即将远走丶或许也能高飞2 小时前
vuex 和 pinia 的学习使用
开发语言·前端·javascript
钟离墨笺2 小时前
Go语言--2go基础-->基本数据类型
开发语言·前端·后端·golang
爱吃泡芙的小白白2 小时前
Vue 3 核心原理与实战:从响应式到企业级应用
前端·javascript·vue.js
卓怡学长3 小时前
m115乐购游戏商城系统
java·前端·数据库·spring boot·spring·游戏
码上成长3 小时前
JavaScript 数组合并性能优化:扩展运算符 vs concat vs 循环 push
开发语言·javascript·ecmascript
老陈聊架构3 小时前
『AI辅助Skill』掌握三大AI设计Skill:前端独立完成产品设计全流程
前端·人工智能·claude·skill
油丶酸萝卜别吃3 小时前
Mapbox GL JS 表达式 (expression) 条件样式设置 完全指南
开发语言·javascript·ecmascript
Ulyanov4 小时前
从桌面到云端:构建Web三维战场指挥系统
开发语言·前端·python·tkinter·pyvista·gui开发
cypking4 小时前
二、前端Java后端对比指南
java·开发语言·前端
摘星编程4 小时前
用React Native开发OpenHarmony应用:timing定时动画参数
javascript·react native·react.js