前端项目打包压缩里

文章介绍了如何通过前端使用compression-webpack-plugin压缩JS和CSS文件,以及在Nginx服务器上开启Gzip功能,以减少前端页面首屏加载时间,实现从2.3MB减小到600KB的效果。
摘要由CSDN通过智能技术生成

客户反映前端页面首屏加载太慢,查了一下是前端项目打包出的js主文件太大,本文方案—前端打包使用compression-webpack-plugin插件压缩静态资源,服务端在Nginx开启Gzip属性。这样Nginx在访问资源时,如果该资源有gz文件,则会请求gz文件。
compression-webpack-plugin:是webpack压缩插件,引入该插件后,npm run build除了会生成压缩后的静态资源(JS、css),还会生成gz形式的JS、CSS。

首先安装插件compression-webpack-plugin

cnpm install compression-webpack-plugin@6.1.1

在配置文件中引入

代码:

 process.env.NODE_ENV === 'production' &&
      addWebpackPlugin(
        new CompressionPlugin({
          // asset: '[path].gz[query]', //目标资源名称。[file] 会被替换成原资源。[path] 会被替换成原资源路径,[query] 替换成原查询字符串
          algorithm: 'gzip', //算法
          test: new RegExp(
            '\\.(js|css)$' //压缩 js 与 css
          ),
          threshold: 10240, //只处理比这个值大的资源。按字节计算
          minRatio: 0.8 //只有压缩率比这个值小的资源才会被处理
        })
      )

如上操作,前端打包出的文件就会小很多, 我这边是2.3M-->600k

需要服务端配合进行Nginx配置:

nginx开启gzip压缩
 

    gzip  on;
    # 开启静态gz文件返回
    gzip_static on;
    gzip_buffers 32 4K;
    gzip_comp_level 6;
    gzip_min_length 1k;
    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 image/x-icon;
    gzip_disable "MSIE [1-6]\."; #配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
    # 是否在http header中添加Vary: Accept-Encoding,建议开启
    gzip_vary on;

将dist文件复制到本地Nginx的html文件中,在Nginx配置跳转:

server {
        listen       3000;
        server_name  localhost;

        location / {
            root   html;
            index  /dist/index.html;
        }
        
        location /static {
            root    html/dist;
        }
    }

在cmd中启动Nginx即可访问localhost:3000.
观察Network可以发现区别(注释Nginx的Gzip即可查看区别)

前端项目打包优化可以从以下几个方面入手: 1. 代码压缩:使用 webpack 的 UglifyJSPlugin 或 TerserPlugin 进行代码压缩,减小代码体积; ``` const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); module.exports = { // ... optimization: { minimizer: [ new UglifyJSPlugin({ uglifyOptions: { compress: { warnings: false, drop_console: true,//去除console.log drop_debugger: true,//去除debugger pure_funcs: ['console.log']//指定移除的函数 } } }) ] } }; ``` 2. Tree shaking:使用 webpack 的 optimize.ModuleConcatenationPlugin 进行模块合并,减少代码冗余; ``` const webpack = require('webpack'); module.exports = { // ... plugins: [ new webpack.optimize.ModuleConcatenationPlugin() ] }; ``` 3. 懒加载:使用 webpack 的 import() 方法实现按需加载,减少首屏加载时间; ``` function getComponent() { return import(/* webpackChunkName: "lodash" */ 'lodash').then(_ => { var element = document.createElement('div'); element.innerHTML = _.join(['Hello', 'webpack'], ' '); return element; }).catch(error => 'An error occurred while loading the component'); } getComponent().then(component => { document.body.appendChild(component); }); ``` 4. CDN 加速:使用外部 CDN 加速加载常用库,减少服务器压力和网络请求时间; ``` <script src="https://cdn.bootcdn.net/ajax/libs/react/17.0.1/umd/react.production.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/react-dom/17.0.1/umd/react-dom.production.min.js"></script> ``` 5. 缓存优化:使用 webpack 的 hash 或 chunkhash 为打包文件添加哈希值,实现静态资源缓存,提高页面加载速度; ``` module.exports = { // ... output: { filename: '[name].[chunkhash].js', path: path.resolve(__dirname, 'dist') } }; ``` 以上是一些常见的前端项目打包优化方法,具体实现可以根据项目需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值