cnpm i compression-webpack-plugin -D
安装依赖包(npm有时候会出错)nginx 配置
listen 80;
server_name saas.saas100.vip 39.100.112.34;
gzip on;
gzip_min_length 1k;
gzip_comp_level 9;
gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
gzip_vary on;
gzip_disable "MSIE [1-6]\.";
location / {
root /app/html/saas/dist;
index index.html index.htm;
}
const path = require('path')
const resolve = dir => {
return path.join(__dirname, dir)
}
const CompressionWebpackPlugin = require('compression-webpack-plugin')
const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
const productionGzipExtensions = ['js', 'css']
const isProduction = process.env.NODE_ENV === 'production'
const cdn = {
// 生产环境
build: {
css: [
'http://unpkg.com/iview/dist/styles/iview.css'
],
js: [
'https://lib.baomitu.com/vue/2.5.10/vue.min.js',
'https://lib.baomitu.com/vuex/3.0.1/vuex.min.js',
'https://lib.baomitu.com/iview/3.2.2/iview.min.js',
'https://lib.baomitu.com/vue-router/3.0.1/vue-router.min.js',
'https://lib.baomitu.com/moment.js/2.24.0/moment.min.js',
'https://lib.baomitu.com/echarts/4.0.4/echarts.min.js'
]
}
}
module.exports = {
//cdn 加载配置
chainWebpack: config => {
config.plugin('html').tap(args => {
if (isProduction) {
args[0].cdn = cdn.build
}
return args
})
},
configureWebpack: config => {
if (isProduction) {
// giz 压缩文件 配置
config.plugins.push(new CompressionWebpackPlugin({
algorithm: 'gzip',
test: new RegExp('\\.(' + productionGzipExtensions.join('|') + ')$'),
threshold: 10240,
minRatio: 0.8
}))
// 过滤console.log
config.plugins.push(
new UglifyJsPlugin({
uglifyOptions: {
warnings: false,
compress: {
drop_console: true,
drop_debugger: true
}
},
sourceMap: false,
// 开启多线程
parallel: true
})
)
// cdn 引入
config.externals = {
'vue': 'Vue',
'vuex': 'Vuex',
'vue-router': 'VueRouter',
'echarts': 'echarts',
'moment': 'moment',
'iview': 'iview'
}
}
},
// 打包时不生成.map文件
productionSourceMap: false
}
cdn在public文件中的index.html加载
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link rel="icon" href="<%= BASE_URL %>favicon.ico">
<% if (htmlWebpackPlugin.options.cdn) {
%>
<% for (var css of htmlWebpackPlugin.options.cdn.css) {
%>
<link rel="stylesheet" href="<%=css%>">
<% }%>
<% }%>
</head>
<body>
<noscript>
<strong>doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
</noscript>
<div id="app"></div>
<% if (htmlWebpackPlugin.options.cdn) {
%>
<% for (var js of htmlWebpackPlugin.options.cdn.js) {
%>
<script src="<%=js%>"></script>
<% }%>
<% }%>
</body>
</html>
Giz帮助理解
在此之前,我有必要解释一下什么编码。当你在互联网上想请求一个文件时,比如http://www.yahoo.com/index.html,你的浏览器会和服务器有一个会话,大概如下如所示。
但是,它生效了,我拿到了index.html文件。
那现在问题在哪呢?
好吧,这系统是正常的,但是太低效了,坦白讲100kb是一大段的文字,HTML是冗余的,每一个都有一个几乎相同的闭合标签。虽然通篇文字都有重复,但是只要你砍掉任何的内容,html(以及它的一奶同胞xml)都不会正常显示。
当文件太大的时候有什么好办法呢,就是gzip压缩它。
如果我们传输一个替代原始大文件的zip的压缩文件给浏览器,就会节省带宽和下载时间。当浏览器可以下载zip文件,解压,并且渲染给用户。下载很快,页面加载也很快,用户心情就会very good。这个浏览器–服务器的会话大概是酱紫的:
情况很简单:文件越小,下载更快,用户感受更好。
nginx, gzip配置帮助理解
gzip使用环境:http,server,location,if(x),一般把它定义在nginx.conf的http{……}之间
推荐文章1
推荐文章2