• vue 性能优化方案


            首先说明一下,我优化的项目是基于vue3 + ts的一个项目,使用的是webpack5的版本,不一定非要是webpack5经测试4也可以正常使用

            若想查看自己当前项目的webpack版本,可以找node_modules目录下面的webpack/package.json文件,查看文件中的version,如下图

    下面开始进入正题

    一、关闭productionSourceMap

             productionSourceMap的作用在于定位问题,打包时会生成.map文件,在生产环境就可以在浏览器查看到输出的信息具体是在哪一行,但相应的包的体积也会变大,将其设置为false则不生成.map文件

    1. module.exports = defineConfig({
    2. productionSourceMap: false,
    3. })

    二、开启gzip

            gzip并不能很好的减小dist包的体积,个人觉的主要作用是在你build后,会生成两份代码,一份压缩的,一份未压缩的,在请求时服务器会优先选择压缩的版本进行返回

    1. // 判断是否是生产环境
    2. const isProduction = process.env.NODE_ENV !== "development";
    3. module.exports = {
    4. configureWebpack: config => {
    5. // 若是生产环境,则执行以下代码
    6. if (isProduction) {
    7. //gzip压缩
    8. const productionGzipExtensions = ["html", "js", "css"];
    9. config.plugins.push(
    10. new CompressionWebpackPlugin({
    11. filename: "[path][base].gz", // 有的版本是[path].gz[query] 根据情况而定
    12. algorithm: "gzip",
    13. test: new RegExp("\\.(" + productionGzipExtensions.join("|") + ")$"),
    14. threshold: 10240, // 只有大小大于该值的资源会被处理 10240
    15. minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理
    16. deleteOriginalAssets: false, // 删除原文件
    17. })
    18. );
    19. }
    20. }
    21. }

    上面配置完后,还需配置下nginx

            在ngxin.conf文件,在http模块填入以下内容

    1. # 开启gzip
    2. gzip on;
    3. # 启用gzip压缩的最小文件,小于设置值的文件将不会压缩
    4. gzip_min_length 1k;
    5. # gzip 压缩级别,1-9,数字越大压缩的越好,也越占用CPU时间,后面会有详细说明
    6. gzip_comp_level 2;
    7. # 进行压缩的文件类型。javascript有多种形式,后面的图片压缩不需要的可以自行删除
    8. 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;
    9. # 是否在http header中添加Vary: Accept-Encoding,建议开启
    10. gzip_vary on;
    11. # 设置压缩所需要的缓冲区大小
    12. gzip_buffers 4 16k;

    然后就可以启动nginx查看效果了,因为我这是测试项目,没有多少东西,所以结果时间相差不大,大家可以自行测试

                                                                    未压缩的

                                                                    压缩后的

     三、开启CDN

            CDN主要是将一些可以在CDN服务器上引用到的插件不进行打包,直接通过CDN链接,从而减小包的体积

            1、首先配置好各个链接地址

            若不知道地址是什么的可通过BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务进行查询,下面是关于cdn链接地址后缀的介绍

    Vue的各种版本介绍:

    1. cjs(两个版本都是完整版,包含编译器)

            vue.cjs.js

            vue.cjs.prod.js(开发版,代码进行了压缩)

    2. global(这四个版本都可以在浏览器中直接通过scripts标签导入,导入之后会增加一个全局的Vue对象)

            vue.global.js(完整版,包含编译器和运行时)

            vue.global.prod.js(完整版,包含编译器和运行时,这是开发版本,代码进行了压缩)         vue.runtime.global.js

            vue.runtime.global.prod.js

    3. browser(四个版本都包含esm,浏览器的原生模块化方式,可以直接通过

  • <% } %>
  • 四、代码压缩

    使用uglifyjs-webpack-plugin插件进行对js的代码压缩优化

    安装插件  npm i -D uglifyjs-webpack-plugin

    然后配置如下内容

    1. const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
    2. module.exports = defineConfig({
    3. configureWebpack: config => {
    4. // 代码压缩
    5. config.plugins.push(
    6. new UglifyJsPlugin({
    7. uglifyOptions: {
    8. //生产环境自动删除console
    9. compress: {
    10. drop_debugger: true,
    11. drop_console: true,
    12. pure_funcs: ['console.log']
    13. }
    14. },
    15. sourceMap: false,
    16. parallel: true
    17. })
    18. )
    19. }
    20. })

    五、图片压缩

    使用image-webpack-loader插件将图片进行压缩

    此插件会将你的图片压缩到一定大小,而一些小图片会被直接压缩成base64格式

    安装插件 npm install image-webpack-loader --save-dev

      我看到有些人也会使用url-loader来压缩图片,url-loader只适用于比较小的图片资源,如果图片很大会导致构建出的.js文件加载缓慢。

      一般会配置小图片使用url-loader完成,而大图片则使用image-webpack-loader进行压缩,不过我测试了一下,发现直接使用image-webpack-loader也可以直接将小图片压缩为base64,所以我这里就直接配置了image-webpack-loader,没有去进行拆分

    配置如下信息

    1. module.exports = defineConfig({
    2. chainWebpack: config => {
    3. // ============压缩图片 start============
    4. config.module
    5. .rule('images')
    6. .use('image-webpack-loader')
    7. .loader('image-webpack-loader')
    8. .options({ bypassOnDebug: true })
    9. .end()
    10. }
    11. })

    目前了解的优化手段大概是这些,如果还有其他方式,还希望老板们也可以分享一下,大家相互学习!

  • 相关阅读:
    VirtualBox VMs 扩展磁盘空间
    三、nginx两种压缩配置[gzip]
    java中的对象克隆(浅克隆和深克隆)
    ORM--查询类型,关联查询
    微服务从代码到k8s部署应有尽有大结局(k8s部署)
    解决Selenium元素拖拽不生效Bug
    线性代数(四)| 解方程 齐次性 非齐次性 扩充问题
    854. 相似度为 K 的字符串(每日一难phase2--day20)
    【Unity】关于升级到2021.3.12之后URP编译错误的问题
    Android发布依赖到 Jitpack
  • 原文地址:https://blog.csdn.net/qq_39215166/article/details/126307391