【webpack】优化提升

webpack优化提升

安装webpack相关内容

  • npm init -y,自动建立package.json
  • npm install webpack webpack-cli npm install webpack-dev-server html-webpack-plugin -D

向下兼容游览器-@babel/polyfill

  • 某些代码在低版本游览器无法兼容使用

  • 采用@babel/polyfill兼容

  • 步骤一:先安装

  • npm i @babel/polyfill -D

  • 页面导入

  • npx webpack打包后最终效果

  • 很多很多的内容,是因为把游览器许多需要优雅降级的一些包都打在这个项目里面了

进一步优化@babel/polyfill

  • 原因:import @babel/polyfill,这样是全局引入整个polyfill包,包体积大,会污染全局环境

  • 采取这个方式

  • npm i exports-loader -D

  • npm install core-js@3

  • 最后页面上删除import @babel/polyfill即可,npx webpack即可

模块联邦-共享模块

  • 直接将一个应用的包应用于另一个应用
  • 同时具备整体应用以及打包的能力
  • 两者的webpack配置
typescript 复制代码
const HtmlWebpackPlugin = require('html-webpack-plugin');
//导入模块联邦
const { ModuleFederationPlugin } = require('webpack').container;

module.exports = {
  mode: 'production',
  entry: './src/index.js',
  plugins: [
    new HtmlWebpackPlugin(),
    //实例化一下
    new ModuleFederationPlugin({
      name: 'nav', //标识联邦模块的名字,别的应用访问这个组件就要通过这个名字
      filename: 'remoteEntry.js', //这个远端使用这个模块的名字
      remotes: {}, //引用其他的联邦模块
      exposes: {
        //暴露组件
        './Header': './src/Header.js', //./Header代表到时候别人用的时候基于这个路径拼接url
      },
      shared: {},
    }),
  ],
};
  • 内容调用

如何提升构建性能

通用环境下
1,webpack更新到最新版本
2,将loader应用于最少数量的必要模块
3,引导(每个额外的loader/plugin都有其启动时间,尽量少使用工具
4,解析
5,小即是快
6,持久化缓存
7,自定义plugin/loader
8,progress plugin
9,dll
  • 注意使用dll的时候,必须先安装jquery
typescript 复制代码
const path = require('path');
const webpack = require('webpack');
module.exports = {
  mode: 'production',
  entry: {
    jquery: ['jquery'],
  },
  output: {
    filename: '[name.js]',
    path: path.resolve(__dirname, 'dll'),
    library: '[name]_[hash]',
  },
  plugins: [
    new webpack.DllPlugin({
      name: '[name]_[hash]',
      path: path.resolve(__dirname, 'dll/manifest.json'),
    }),
  ],
};
  • 然后package.json里配置一下
  • 运行时间就会降低了

  • 注意,此时提升了构建速度,但画面是不行的
  • 要再配置一下webpack.config.js
10,worker池
  • 注意,不要使用太多的worker,因为node.js的runtime和loader都有启动开销,启动会消耗时间
  • 当遇到比较大的进程,再使用
  • npm i thread-loader -D
  • 在webpack.config.js中
typescript 复制代码
module.exports = {
  mode: 'development',
  entry: './src/index.js',
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: [
          //使用worker池分流
          {
            loader: 'thread-loader',
            options: {
              workers: 2,
            },
          },
          {
            //目的,解析一些es6的代码
            loader: 'babel-loader',
            options: {
              presets: ['@babel/preset-env'],
            },
          },
        ],
      },
    ],
  },
};
开发环境下
1,增量编译
2,在内存中编译
3,stats.to.Json加速
4,Devtool
5,避免在生产环境才用到的工具
6,最小化 entry chunk
7,避免额外的优化步骤
8,输出结果不携带路径信息
9,Node.js版本问题
TypeScript Loader
生产环境下
不启用sourcMap
相关推荐
gAlAxy...1 小时前
IntelliJ IDEA 四种项目构建:从普通 Java 到 Maven Web 项目
前端·firefox
my一阁1 小时前
2025-web集群-问题总结
前端·arm开发·数据库·nginx·负载均衡·web
会飞的小妖1 小时前
个人博客系统(十一、前端-简短的配置)
前端
念念不忘 必有回响3 小时前
nginx前端部署与Vite环境变量配置指南
前端·nginx·vite
JIngJaneIL3 小时前
篮球论坛|基于SprinBoot+vue的篮球论坛系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·篮球论坛系统
程序猿阿伟5 小时前
《首屏加载优化手册:Vue3+Element Plus项目提速的技术细节》
前端·javascript·vue.js
fruge6 小时前
Vue Pinia 状态管理实战指南
前端·vue.js·ubuntu
sean7 小时前
开发一个自己的 claude code
前端·后端·ai编程
用户21411832636027 小时前
dify案例分享-用 Dify 一键生成教学动画 HTML!AI 助力,3 分钟搞定专业级课件
前端
太过平凡的小蚂蚁9 小时前
Kotlin 协程中常见的异步返回与控制方式(速览)
开发语言·前端·kotlin