从多个方面详述build:prod

一、build:prod概述

build:prod是指在项目开发完成之后,将代码打包成最终可以上线的版本。一般而言,通过build:prod进行打包会减小代码大小、提高性能、优化体验以及保障安全等方面的目标。

在Vue项目中,我们可以通过执行npm run build:prod来进行打包,最终的打包文件会生成在/dist目录下。下面我们将从代码优化、性能提升、体验优化、安全保障等方面对build:prod进行详细阐述。

二、代码的优化

在代码的优化方面,主要从三个方面入手:文件压缩、代码分割和 Tree Shaking 。

1、文件压缩

// bable.config.js

module.exports = {

  ...

  // 压缩JS代码

  presets: [

    ['@babel/preset-env', {

      useBuiltIns: false,

      corejs: false,

      modules: false,

      targets: {

        browsers: [

          '> 1%',

          'last 2 versions',

          'not ie <= 8',

        ],

      },

    }],

  ],

  // 压缩CSS代码

  plugins: [

    ...

    new OptimizeCSSAssetsPlugin({

      assetNameRegExp: /\.css$/g,

      cssProcessor: require('cssnano'),

      cssProcessorPluginOptions: {

        preset: ['default', {

          discardComments: {

            removeAll: true,

          },

          normalizeUnicode: false,

        }],

      },

      canPrint: true,

    }),

    ...

  ],

}

以上的配置表明了在打包生产环境的文件时,需要对JS和CSS代码进行压缩。其中使用了@babel/preset-env和cssnano等第三方库进行压缩,同时可以选择移除注释、一些特殊字符等内容,从而减小文件大小。

2、代码分割

// webpack.config.js

const HtmlWebpackPlugin = require('html-webpack-plugin');

const webpack = require('webpack');

module.exports = {

  ...

  // 使用webpack的splitChunks进行代码分割

  optimization: {

    splitChunks: {

      chunks: 'all',

      name: 'vendor',

    },

  },

  plugins: [

    ...

    // 使用HtmlWebpackPlugin注入产生的vendor.js

    new HtmlWebpackPlugin({

      ...

      chunks: ['vendor', 'main'],

      ...

    }),

    ...

  ],

  ...

};

以上的配置表明了在打包生产环境的文件时,webpack会将代码拆分成多个文件,这些文件会被单独引入,从而减少页面加载时间。

3、Tree Shaking

// webpack.config.js

const UglifyJSPlugin = require('uglifyjs-webpack-plugin');

module.exports = {

  ...

  // 开启Tree Shaking,需要使用uglifyjs压缩JS代码

  optimization: {

    minimize: true,

    minimizer: [new UglifyJSPlugin({

      cache: true,

      parallel: true,

      sourceMap: false,

      extractComments: false,

      uglifyOptions: {

        // 开启Tree Shaking

        compress: {

          unused: true,

          drop_debugger: true,

          drop_console: true,

          pure_funcs: ['console.log'],

        },

      },

    })],

  },

  ...

};

以上的配置表明了在打包生产环境的文件时,会进行Tree Shaking机制,去掉无用的代码。开启Tree Shaking需要使用uglifyjs插件。

三、性能的提升

在性能的提升方面,主要从两个方面入手:打包速度和页面加载速度。

1、打包速度

// vue.config.js

module.exports = {

  ...

  // 开启parallel配置来提高打包速度

  configureWebpack: {

    ...

    plugins: [],

    performance: {

      hints: false,

    },

  },

  parallel: require('os').cpus().length > 1,

  ...

};

以上的配置表明了在打包生产环境的文件时,开启parallel配置可以提高打包速度。

2、页面加载速度

// vue.config.js

module.exports = {

  ...

  // 对静态资源进行gzip压缩

  configureWebpack: {

    ...

  },

  pluginOptions: {

    compression: {

      algorithm: 'gzip',

      test: /\.js$|\.html$|\.json$|\.css/,

      threshold: 10240,

      minRatio: 0.8,

      deleteOriginalAssets: false,

    },

  },

  ...

};

以上的配置表明了在打包生产环境的文件时,对静态资源进行gzip压缩以减小文件大小,从而提高页面加载速度。

四、体验的优化

在体验的优化方面,主要从两个方面入手:打包文件的结果进行分析以及Web Workers。

1、打包文件的结果进行分析

module.exports = {

  ...

  // 分析打包文件的结果

  plugins: [

    ...

    new BundleAnalyzerPlugin({

      analyzerMode: 'static',

      openAnalyzer: false,

    }),

    ...

  ],

  ...

};

以上的配置表明了在打包生产环境的文件时,可以分析打包文件的结果,以便了解打包文件是否有冗余代码以及文件大小占比等信息,从而进行相应的优化。

2、Web Workers

// 异步处理用户数据

if (window.Worker) {

  const worker = new Worker('./user.worker.js');

  worker.onmessage = (event) => {

    console.log(event.data);

  };

  worker.postMessage({

    type: 'getText',

    message: 'bundle',

  });

} else {

  // fallback

}

以上的代码表明了使用Web Workers进行异步处理,可以在页面处理数据时提高响应速度,从而优化用户体验。

五、安全保障

在安全保障方面,主要从两个方面入手:CSRF攻击和XSS攻击。

1、CSRF攻击

// vue.config.js

module.exports = {

  ...

  // 在webpack.config.js中使用CopyWebpackPlugin拷贝不经过处理的静态资源代码

  // 在vue.config.js中使用compression-webpack-plugin压缩静态资源代码

  configureWebpack: {

    ...

    plugins: [

      ...

      new CopyWebpackPlugin([{

        from: path.resolve(__dirname, 'src/assets'),

        to: path.resolve(__dirname, 'dist/assets'),

        ignore: ['.*'],

      }]),

      ...

    ],

  },

  pluginOptions: {

    compression: {

      algorithm: 'gzip',

      test: /\.js$|\.html$|\.json$|\.css/,

      threshold: 10240,

      minRatio: 0.8,

      deleteOriginalAssets: false,

    },

  },

  ...

};

以上的配置表明了在打包生产环境的文件时,可以使用CopyWebpackPlugin拷贝不经过处理的静态资源代码,并使用compression-webpack-plugin压缩静态资源代码,从而避免被黑客在前端代码中注入恶意代码,防止CSRF攻击。

2、XSS攻击

// 引入DOMPurify库进行HTML过滤

import DOMPurify from 'dompurify';

...

this.$refs.content.innerHTML = DOMPurify.sanitize(this.html);

以上的代码表明了在前端页面渲染HTML代码时,可以使用DOMPurify库进行HTML过滤,从而防止被黑客在前端代码中注入恶意代码,防止XSS攻击。

原创文章,作者:POIQ,如若转载,请注明出处:https://www.506064.com/n/134262.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
POIQPOIQ
上一篇 2024-10-04 00:04
下一篇 2024-10-04 00:04

相关推荐

  • 为什么Python不能编译?——从多个方面浅析原因和解决方法

    Python作为很多开发人员、数据科学家和计算机学习者的首选编程语言之一,受到了广泛关注和应用。但与之伴随的问题之一是Python不能编译,这给基于编译的开发和部署方式带来不少麻烦…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • Python合并多个相同表头文件

    对于需要合并多个相同表头文件的情况,我们可以使用Python来实现快速的合并。 一、读取CSV文件 使用Python中的csv库读取CSV文件。 import csv with o…

    编程 2025-04-29
  • 从多个方面用法介绍yes,but let me review and configure level of access

    yes,but let me review and configure level of access是指在授权过程中,需要进行确认和配置级别控制的全能编程开发工程师。 一、授权确…

    编程 2025-04-29
  • 从多个方面zmjui

    zmjui是一个轻量级的前端UI框架,它实现了丰富的UI组件和实用的JS插件,让前端开发更加快速和高效。本文将从多个方面对zmjui做详细阐述,帮助读者深入了解zmjui,以便更好…

    编程 2025-04-28
  • 学Python用什么编辑器?——从多个方面评估各种Python编辑器

    选择一个适合自己的 Python 编辑器并不容易。除了我们开发的应用程序类型、我们面临的软件架构以及我们的编码技能之外,选择编辑器可能也是我们编写代码时最重要的决定之一。随着许多不…

    编程 2025-04-28
  • 使用easypoi创建多个动态表头

    本文将详细介绍如何使用easypoi创建多个动态表头,让表格更加灵活和具有可读性。 一、创建单个动态表头 easypoi是一个基于POI操作Excel的Java框架,支持通过注解的…

    编程 2025-04-28
  • 创建列表的多个方面

    本文将从多个方面对创建列表进行详细阐述。 一、列表基本概念 列表是一种数据结构,其中元素以线性方式组织,并且具有特殊的序列位置。该位置可以通过索引或一些其他方式进行访问。在编程中,…

    编程 2025-04-28
  • Python多个sheet表合并用法介绍

    本文将从多个方面对Python多个sheet表合并进行详细的阐述。 一、xlrd与xlwt模块的基础知识 xlrd与xlwt是Python中处理Excel文件的重要模块。xlrd模…

    编程 2025-04-27
  • 从多个角度用法介绍lower down

    lower down是一个常用于编程开发中的操作。它可以对某个值或变量进行降低精度的处理,非常适合于一些需要精度不高但速度快的场景。那么,在本文中,我们将从多个角度解析lower …

    编程 2025-04-27

发表回复

登录后才能评论